@fernir2/saas-kit 0.0.206 → 0.0.208
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/cli/package-template.json +13 -13
- package/dist/styles.css +2 -2
- package/flint/index.d.ts +1 -0
- package/flint/index.js +1 -0
- package/generated/crud-handler-map.js +1 -1
- package/generated/meta.json +5 -14
- package/generated/schema.d.ts +17 -0
- package/generated/schema.js +1 -1
- package/index.d.ts +9 -5
- package/index.js +9 -5
- package/internal/index.d.ts +7 -4
- package/internal/index.js +7 -4
- package/package.json +30 -47
- package/packages/base-repo/app-constants/alias-symbols.d.ts +1 -0
- package/packages/base-repo/app-constants/alias-symbols.js +1 -1
- package/packages/base-repo/app-constants/aliases.js +1 -1
- package/packages/base-repo/app-constants/project-paths.d.ts +18 -1
- package/packages/base-repo/app-constants/project-paths.js +1 -1
- package/packages/base-repo/app-constants/system-constants.d.ts +69 -0
- package/packages/base-repo/app-constants/system-constants.js +5 -4
- package/packages/base-repo/constants/basic-types.d.ts +2 -0
- package/packages/base-repo/constants/basic-types.js +1 -1
- package/packages/base-repo/constants/ci-constants.d.ts +1 -0
- package/packages/base-repo/constants/ci-constants.js +2 -1
- package/packages/base-repo/constants/common-strings.d.ts +136 -0
- package/packages/base-repo/constants/common-strings.js +4 -0
- package/packages/base-repo/constants/country-data.d.ts +30 -0
- package/packages/base-repo/constants/country-data.js +4 -0
- package/packages/base-repo/constants/display-labels.d.ts +3 -0
- package/packages/base-repo/constants/display-labels.js +4 -0
- package/packages/base-repo/constants/extensions.d.ts +4 -1
- package/packages/base-repo/constants/extensions.js +2 -2
- package/packages/base-repo/constants/html-element-names.d.ts +10 -0
- package/packages/base-repo/constants/html-element-names.js +6 -0
- package/packages/base-repo/constants/packages.d.ts +1 -0
- package/packages/base-repo/constants/packages.js +1 -1
- package/packages/base-repo/constants/playwright.js +3 -1
- package/packages/base-repo/constants/push-statuses.d.ts +2 -0
- package/packages/base-repo/constants/push-statuses.js +1 -1
- package/packages/base-repo/constants/string-duplication-constants.d.ts +3 -3
- package/packages/base-repo/constants/string-duplication-constants.js +1 -1
- package/packages/base-repo/constants/tools-constants.d.ts +186 -4
- package/packages/base-repo/constants/tools-constants.js +4 -2
- package/packages/cluster/ci/gitlab-runner.d.ts +2 -1
- package/packages/cluster/ci/gitlab-runner.js +2 -2
- package/packages/cluster/ci/pnpm-cache-pv-pvc.d.ts +5 -0
- package/packages/cluster/ci/pnpm-cache-pv-pvc.js +7 -0
- package/packages/cluster/constants/cluster-constants.d.ts +15 -0
- package/packages/cluster/constants/cluster-constants.js +2 -2
- package/packages/cluster/create-vm/config-dev-vm.d.ts +2 -0
- package/packages/cluster/create-vm/config-dev-vm.js +2 -2
- package/packages/cluster/create-vm/create-vm.d.ts +2 -0
- package/packages/cluster/create-vm/create-vm.js +16 -16
- package/packages/cluster/db/postgres.d.ts +2 -2
- package/packages/cluster/db/postgres.js +2 -2
- package/packages/cluster/index.js +2 -1
- package/packages/cluster/kube/namespaces.js +2 -2
- package/packages/cluster/kube/networking.js +2 -2
- package/packages/cluster/kube/registry.js +3 -3
- package/packages/code-quality/significant-line-counter/reviewable-commit-diff.d.ts +22 -0
- package/packages/code-quality/significant-line-counter/reviewable-commit-diff.js +7 -0
- package/packages/code-quality/significant-line-counter/significant-line-check-result.d.ts +18 -0
- package/packages/code-quality/significant-line-counter/significant-line-check-result.js +8 -0
- package/packages/code-quality/significant-line-counter/significant-line-check-statuses.d.ts +5 -0
- package/packages/code-quality/significant-line-counter/significant-line-check-statuses.js +6 -0
- package/packages/code-quality/significant-line-counter/significant-line-counter.d.ts +1 -0
- package/packages/code-quality/significant-line-counter/significant-line-counter.js +4 -0
- package/packages/fd-toolbox/api/api-client.js +1 -1
- package/packages/fd-toolbox/api/api-path-names.d.ts +0 -1
- package/packages/fd-toolbox/api/api-path-names.js +2 -1
- package/packages/fd-toolbox/api/api-paths.js +1 -1
- package/packages/fd-toolbox/api/base-api.js +1 -1
- package/packages/fd-toolbox/api/cache-headers.js +1 -1
- package/packages/fd-toolbox/api/hooks/use-api.js +1 -1
- package/packages/fd-toolbox/auth/login-states.js +1 -1
- package/packages/fd-toolbox/auth/oauth-service-types.d.ts +5 -0
- package/packages/fd-toolbox/auth/oauth-service-types.js +2 -2
- package/packages/fd-toolbox/auth/permissions/permission-notifiers.js +1 -1
- package/packages/fd-toolbox/auth/register.d.ts +0 -5
- package/packages/fd-toolbox/auth/register.js +2 -2
- package/packages/fd-toolbox/auth/session-storage.js +1 -1
- package/packages/fd-toolbox/auth/tokens.js +1 -1
- package/packages/fd-toolbox/base-resource/base-resource.js +1 -1
- package/packages/fd-toolbox/base-resource/optional-user-id-base-resource.js +1 -1
- package/packages/fd-toolbox/base-resource/user-id-base-resource.js +1 -1
- package/packages/fd-toolbox/cache/cache.js +1 -1
- package/packages/fd-toolbox/collections/arrays.d.ts +2 -0
- package/packages/fd-toolbox/collections/arrays.js +2 -2
- package/packages/fd-toolbox/collections/enums.js +1 -1
- package/packages/fd-toolbox/constants/auth-constants.d.ts +0 -2
- package/packages/fd-toolbox/constants/auth-constants.js +2 -2
- package/packages/fd-toolbox/constants/auth-display-labels.d.ts +4 -0
- package/packages/fd-toolbox/constants/auth-display-labels.js +4 -0
- package/packages/fd-toolbox/constants/card-list-configs.d.ts +1 -1
- package/packages/fd-toolbox/constants/child-process-events.d.ts +1 -0
- package/packages/fd-toolbox/constants/child-process-events.js +3 -1
- package/packages/fd-toolbox/constants/common-user-fields.d.ts +2 -0
- package/packages/fd-toolbox/constants/common-user-fields.js +4 -1
- package/packages/fd-toolbox/constants/constants.d.ts +7 -1
- package/packages/fd-toolbox/constants/constants.js +2 -2
- package/packages/fd-toolbox/constants/element-suffixes.js +2 -2
- package/packages/fd-toolbox/constants/file-loader-data-types.js +3 -1
- package/packages/fd-toolbox/constants/html-constants.d.ts +26 -0
- package/packages/fd-toolbox/constants/html-constants.js +6 -0
- package/packages/fd-toolbox/constants/keyboard-keys.js +2 -2
- package/packages/fd-toolbox/constants/meta-query-params.js +3 -1
- package/packages/fd-toolbox/constants/odata-helper-constants.js +1 -1
- package/packages/fd-toolbox/constants/public-files.js +2 -1
- package/packages/fd-toolbox/constants/scroll-position-constants.d.ts +3 -0
- package/packages/fd-toolbox/constants/scroll-position-constants.js +4 -0
- package/packages/fd-toolbox/dates/date-time.d.ts +11 -0
- package/packages/fd-toolbox/dates/date-time.js +9 -9
- package/packages/fd-toolbox/enums/enums.d.ts +2 -2
- package/packages/fd-toolbox/enums/enums.js +3 -2
- package/packages/fd-toolbox/errors/error-handler.js +2 -2
- package/packages/fd-toolbox/errors/errors.js +1 -1
- package/packages/fd-toolbox/errors/problem-details.js +1 -1
- package/packages/fd-toolbox/functions/condition-check-functions.js +1 -1
- package/packages/fd-toolbox/functions/value-checking-functions.js +2 -1
- package/packages/fd-toolbox/hooks/use-async-effect.js +2 -1
- package/packages/fd-toolbox/hooks/use-element-id.js +1 -1
- package/packages/fd-toolbox/hooks/use-empty-ref.js +1 -1
- package/packages/fd-toolbox/hooks/use-enter-key.js +1 -1
- package/packages/fd-toolbox/hooks/use-is-client.js +1 -1
- package/packages/fd-toolbox/hooks/use-is-mobile.js +1 -1
- package/packages/fd-toolbox/hooks/use-keyboard-navigation.js +1 -1
- package/packages/fd-toolbox/hooks/use-media-query.js +1 -1
- package/packages/fd-toolbox/hooks/use-optional-promise.js +1 -1
- package/packages/fd-toolbox/html/element-ids.js +1 -1
- package/packages/fd-toolbox/html/extract-emails-from-html.js +1 -1
- package/packages/fd-toolbox/html/markdown-renderer.js +1 -1
- package/packages/fd-toolbox/http/http.js +1 -1
- package/packages/fd-toolbox/http/url/url-builder.js +1 -1
- package/packages/fd-toolbox/http/url/urls.js +1 -1
- package/packages/fd-toolbox/infra/env-config.js +2 -2
- package/packages/fd-toolbox/infra/env-functions.js +5 -4
- package/packages/fd-toolbox/infra/env-schema.d.ts +2 -291
- package/packages/fd-toolbox/infra/env-schema.js +2 -9
- package/packages/fd-toolbox/io/io.js +1 -1
- package/packages/fd-toolbox/lib/environments.d.ts +2 -0
- package/packages/fd-toolbox/lib/environments.js +3 -3
- package/packages/fd-toolbox/lib/utils.js +1 -1
- package/packages/fd-toolbox/local-storage/local-storage.js +1 -1
- package/packages/fd-toolbox/logging/cli-logger.d.ts +2 -2
- package/packages/fd-toolbox/logging/cli-logger.js +2 -3
- package/packages/fd-toolbox/logging/format-list.d.ts +3 -0
- package/packages/fd-toolbox/logging/format-list.js +4 -0
- package/packages/fd-toolbox/logging/loggers.d.ts +1 -0
- package/packages/fd-toolbox/logging/loggers.js +1 -1
- package/packages/fd-toolbox/notifications.js +2 -2
- package/packages/fd-toolbox/numbers/numbers.js +1 -1
- package/packages/fd-toolbox/objects/property-value.js +1 -1
- package/packages/fd-toolbox/odata/odata-builder-funcs.js +1 -1
- package/packages/fd-toolbox/odata/odata-builders.js +1 -1
- package/packages/fd-toolbox/odata/odata-constants.js +1 -1
- package/packages/fd-toolbox/odata/odata.js +2 -2
- package/packages/fd-toolbox/odata/odataconfig.js +1 -1
- package/packages/fd-toolbox/odata/services/odata-filters.js +1 -1
- package/packages/fd-toolbox/odata/services/odata-parsers.js +1 -1
- package/packages/fd-toolbox/path.js +1 -1
- package/packages/fd-toolbox/paths/ensure.js +1 -1
- package/packages/fd-toolbox/paths/paths-names.js +1 -1
- package/packages/fd-toolbox/property/calculate-total-property-value.js +1 -1
- package/packages/fd-toolbox/redirect/redirect-functions.js +1 -1
- package/packages/fd-toolbox/routing/login-routers.js +1 -1
- package/packages/fd-toolbox/routing/paths.js +1 -1
- package/packages/fd-toolbox/routing/public-routes.d.ts +1 -1
- package/packages/fd-toolbox/routing/public-routes.js +1 -1
- package/packages/fd-toolbox/routing/routers.js +1 -1
- package/packages/fd-toolbox/routing/routes.d.ts +0 -6
- package/packages/fd-toolbox/routing/routes.js +3 -2
- package/packages/fd-toolbox/server/api/odata/odata-query-params.js +4 -1
- package/packages/fd-toolbox/server/api/public-api-routes.js +1 -1
- package/packages/fd-toolbox/server/api/query-params.js +1 -1
- package/packages/fd-toolbox/server/api-enums/content-type.d.ts +2 -2
- package/packages/fd-toolbox/server/api-enums/content-type.js +4 -6
- package/packages/fd-toolbox/server/auth/cookies.js +1 -1
- package/packages/fd-toolbox/server/cachings/core-cache.js +1 -1
- package/packages/fd-toolbox/server/cachings/fd-memory-cache.js +1 -1
- package/packages/fd-toolbox/server/cachings/fd-remote-cache.js +2 -2
- package/packages/fd-toolbox/server/collections/single-funcs.d.ts +5 -3
- package/packages/fd-toolbox/server/collections/single-funcs.js +2 -2
- package/packages/fd-toolbox/server/configs/configs.js +2 -2
- package/packages/fd-toolbox/server/constants/crud-actions-constants.js +2 -2
- package/packages/fd-toolbox/server/constants/fd-server-cache-keys.js +1 -1
- package/packages/fd-toolbox/server/entities/base-objects.js +1 -1
- package/packages/fd-toolbox/server/errors/error-dtos.js +1 -1
- package/packages/fd-toolbox/server/framework/index.js +1 -1
- package/packages/fd-toolbox/server/logging/latest-logs-store.js +1 -1
- package/packages/fd-toolbox/server/logging/log-dtos.js +1 -1
- package/packages/fd-toolbox/server/logging/logger.js +2 -2
- package/packages/fd-toolbox/server/objects/keys-case-converters.js +1 -1
- package/packages/fd-toolbox/server/random.js +1 -1
- package/packages/fd-toolbox/server/services/dictionaries.js +1 -1
- package/packages/fd-toolbox/server/strings/casing.js +1 -1
- package/packages/fd-toolbox/server/strings/strings.js +1 -1
- package/packages/fd-toolbox/server/time/duration-service.js +1 -1
- package/packages/fd-toolbox/server/web/errors.js +1 -1
- package/packages/fd-toolbox/state/component-states.js +1 -1
- package/packages/fd-toolbox/strings/case-converters.js +1 -1
- package/packages/fd-toolbox/strings/casing-converter.js +1 -1
- package/packages/fd-toolbox/strings/plural-converters.js +1 -1
- package/packages/fd-toolbox/strings/strings-constants.js +1 -1
- package/packages/fd-toolbox/strings/strings.js +1 -1
- package/packages/fd-toolbox/time/date-time.js +1 -1
- package/packages/fd-toolbox/types/crud/crud-results.js +1 -1
- package/packages/fd-toolbox/types/ensure-type.js +2 -1
- package/packages/fd-toolbox/url/urls.js +1 -1
- package/packages/fd-toolbox/uuids.js +1 -1
- package/packages/fd-toolbox/value-checkers.js +1 -1
- package/packages/fd-toolbox-core/constants/base-dev-url.js +1 -1
- package/packages/fd-toolbox-core/constants/meta-constants.js +3 -1
- package/packages/fd-toolbox-core/core/name-of.js +1 -1
- package/packages/fd-toolbox-core/types/resource-with-id.js +1 -1
- package/packages/flint/dist/rules/index.d.ts +11 -0
- package/packages/flint/dist/rules/index.js +9 -9
- package/packages/flint/eslint-base.config.d.ts +1 -0
- package/packages/flint/eslint-base.config.js +13 -13
- package/packages/flint/eslint-next-web-vitals-temp.config.d.ts +2 -2
- package/packages/flint/eslint-next-web-vitals-temp.config.js +2 -2
- package/packages/flint/infra/analysis/array-analysis.d.ts +1 -1
- package/packages/flint/infra/analysis/array-analysis.js +2 -2
- package/packages/flint/infra/analysis/callable-analysis.d.ts +4 -0
- package/packages/flint/infra/analysis/callable-analysis.js +7 -0
- package/packages/flint/infra/analysis/casing-analysis.js +1 -1
- package/packages/flint/infra/analysis/enum-analysis.d.ts +2 -2
- package/packages/flint/infra/analysis/enum-analysis.js +1 -1
- package/packages/flint/infra/analysis/eslint-analysis.d.ts +1 -1
- package/packages/flint/infra/analysis/eslint-analysis.js +1 -1
- package/packages/flint/infra/analysis/expression-analysis.js +5 -2
- package/packages/flint/infra/analysis/formatting-analysis.js +1 -1
- package/packages/flint/infra/analysis/function-analysis.d.ts +5 -2
- package/packages/flint/infra/analysis/function-analysis.js +6 -4
- package/packages/flint/infra/analysis/generic-analysis.d.ts +21 -0
- package/packages/flint/infra/analysis/generic-analysis.js +7 -0
- package/packages/flint/infra/analysis/jsx-analysis.d.ts +1 -1
- package/packages/flint/infra/analysis/jsx-analysis.js +1 -1
- package/packages/flint/infra/analysis/module-analysis.d.ts +5 -2
- package/packages/flint/infra/analysis/module-analysis.js +4 -4
- package/packages/flint/infra/analysis/name-analysis.d.ts +3 -2
- package/packages/flint/infra/analysis/name-analysis.js +5 -5
- package/packages/flint/infra/analysis/nullish-analysis.d.ts +1 -1
- package/packages/flint/infra/analysis/nullish-analysis.js +1 -1
- package/packages/flint/infra/analysis/number-analysis.d.ts +2 -2
- package/packages/flint/infra/analysis/number-analysis.js +1 -1
- package/packages/flint/infra/analysis/object-analysis.d.ts +1 -1
- package/packages/flint/infra/analysis/object-analysis.js +2 -2
- package/packages/flint/infra/analysis/path-analysis.d.ts +1 -0
- package/packages/flint/infra/analysis/path-analysis.js +4 -0
- package/packages/flint/infra/analysis/return-analysis.d.ts +4 -2
- package/packages/flint/infra/analysis/return-analysis.js +2 -2
- package/packages/flint/infra/analysis/scope-analysis.js +6 -5
- package/packages/flint/infra/analysis/string-analysis.d.ts +2 -2
- package/packages/flint/infra/analysis/string-analysis.js +2 -2
- package/packages/flint/infra/analysis/test-analysis.d.ts +2 -0
- package/packages/flint/infra/analysis/test-analysis.js +6 -0
- package/packages/flint/infra/analysis/tree-analysis.d.ts +3 -2
- package/packages/flint/infra/analysis/tree-analysis.js +2 -2
- package/packages/flint/infra/analysis/type-analysis.d.ts +2 -14
- package/packages/flint/infra/analysis/type-analysis.js +4 -4
- package/packages/flint/infra/analysis/type-guards.d.ts +10 -4
- package/packages/flint/infra/analysis/type-guards.js +2 -2
- package/packages/flint/infra/analysis/variable-analysis.d.ts +3 -1
- package/packages/flint/infra/analysis/variable-analysis.js +5 -4
- package/packages/flint/infra/analysis/visitors.d.ts +1 -1
- package/packages/flint/infra/analysis/visitors.js +1 -1
- package/packages/flint/infra/config-edited-checker.js +3 -3
- package/packages/flint/infra/create-eslint-rule.d.ts +3 -2
- package/packages/flint/infra/create-eslint-rule.js +1 -1
- package/packages/flint/infra/git-readers.js +3 -3
- package/packages/flint/project-specific-eslint-configs.js +7 -7
- package/packages/flint/rules/code-duplication/must-avoid-code-duplication-in-functions.js +1 -1
- package/packages/flint/rules/code-duplication/no-duplicate-imports.js +1 -1
- package/packages/flint/rules/code-duplication/no-literal-duplication.js +1 -1
- package/packages/flint/rules/consistency/enum-type-immediate-definition.js +1 -1
- package/packages/flint/rules/consistency/must-not-needlessly-copy-arrays.js +2 -2
- package/packages/flint/rules/consistency/must-not-use-anonymous-objects-only-with-explicit-typization.js +1 -1
- package/packages/flint/rules/consistency/must-not-use-process-env.js +1 -1
- package/packages/flint/rules/consistency/must-use-nameof-for-props.js +1 -1
- package/packages/flint/rules/consistency/must-use-typed-resources-for-crud-update.js +3 -2
- package/packages/flint/rules/consistency/must-use-typescript.js +1 -1
- package/packages/flint/rules/consistency/no-index-import-in-ast-helpers.js +1 -1
- package/packages/flint/rules/consistency/no-new-date.js +1 -1
- package/packages/flint/rules/consistency/no-redundant-type-alias.js +1 -1
- package/packages/flint/rules/consistency/no-use-type-undefined-for-optional.js +1 -1
- package/packages/flint/rules/css/must-not-use-important.js +1 -1
- package/packages/flint/rules/css/no-array-destructuring-from-function-calls.js +1 -1
- package/packages/flint/rules/css/no-px-in-tailwind.js +1 -1
- package/packages/flint/rules/css/no-tailwind-colors.js +1 -1
- package/packages/flint/rules/flint/must-add-custom-rule-in-config.js +3 -3
- package/packages/flint/rules/flint/must-have-both-rule-and-tests.js +3 -3
- package/packages/flint/rules/flint/must-match-rule-name-with-file-name.js +2 -2
- package/packages/flint/rules/flint/must-not-declare-fixer-without-calling-it.js +1 -1
- package/packages/flint/rules/flint/must-not-import-ast-node-types.js +1 -1
- package/packages/flint/rules/flint/must-not-use-eslint-deprecated-methods.js +1 -1
- package/packages/flint/rules/flint/must-not-use-the-single-error-property-in-test.d.ts +3 -0
- package/packages/flint/rules/flint/must-not-use-the-single-error-property-in-test.js +7 -0
- package/packages/flint/rules/flint/must-use-better-error-message-for-custom-rules.js +1 -1
- package/packages/flint/rules/flint/must-use-constants-for-message-ids.js +1 -1
- package/packages/flint/rules/flint/must-use-create-eslint-rule.js +1 -1
- package/packages/flint/rules/flint/must-use-generic-crud-update-config.d.ts +3 -0
- package/packages/flint/rules/flint/must-use-generic-crud-update-config.js +7 -0
- package/packages/flint/rules/flint/must-use-link-for-camel-or-pascal-case-names.js +3 -3
- package/packages/flint/rules/flint/must-use-nodetypes-structure-instead-of-string-node-type.js +1 -1
- package/packages/flint/rules/flint/must-use-rule-name-as-message-id-in-tests.js +1 -1
- package/packages/flint/rules/flint/must-use-unique-filenames-with-comment-in-tests.js +1 -1
- package/packages/flint/rules/general/group-consts-as-const.js +1 -1
- package/packages/flint/rules/general/must-add-space-for-comments.js +1 -1
- package/packages/flint/rules/general/must-create-resources-in-src-dir.js +1 -1
- package/packages/flint/rules/general/must-not-define-functions-in-constants-files.js +1 -1
- package/packages/flint/rules/general/must-not-include-unnecessary-parameters.d.ts +3 -0
- package/packages/flint/rules/general/must-not-include-unnecessary-parameters.js +7 -0
- package/packages/flint/rules/general/must-not-pass-full-objects-into-functions-needlessly.js +2 -2
- package/packages/flint/rules/general/must-start-comments-with-uppercase.js +1 -1
- package/packages/flint/rules/general/must-use-native-private.js +1 -1
- package/packages/flint/rules/general/must-use-path-constants-for-paths.d.ts +3 -0
- package/packages/flint/rules/general/must-use-path-constants-for-paths.js +8 -0
- package/packages/flint/rules/general/must-use-strict-dependency-version.js +1 -1
- package/packages/flint/rules/general/no-empty-files.js +1 -1
- package/packages/flint/rules/general/no-eslint-disable-without-approved.d.ts +1 -1
- package/packages/flint/rules/general/no-eslint-disable-without-approved.js +1 -1
- package/packages/flint/rules/general/no-import-from-temp-dev.js +1 -1
- package/packages/flint/rules/general/no-specify-return-type.js +1 -1
- package/packages/flint/rules/general/no-todo.js +1 -1
- package/packages/flint/rules/general/no-unused-properties-in-constants.d.ts +3 -0
- package/packages/flint/rules/general/no-unused-properties-in-constants.js +7 -0
- package/packages/flint/rules/general/use-of-only-english-in-repository.js +1 -1
- package/packages/flint/rules/index.js +150 -139
- package/packages/flint/rules/must-always-specify-types-for-api-responses.js +1 -1
- package/packages/flint/rules/must-declare-module-members-in-consistent-order.js +4 -2
- package/packages/flint/rules/must-not-modify-data-or-workspace-in-readonly-tests.js +3 -1
- package/packages/flint/rules/must-not-return-empty-strings.js +3 -1
- package/packages/flint/rules/must-not-use-all-caps-constants.js +3 -2
- package/packages/flint/rules/must-not-use-fetch.js +1 -1
- package/packages/flint/rules/must-not-use-inline-object-type-parameters.js +1 -1
- package/packages/flint/rules/must-not-use-multiple-get-id-functions-inline-in-test.d.ts +3 -0
- package/packages/flint/rules/must-not-use-multiple-get-id-functions-inline-in-test.js +7 -0
- package/packages/flint/rules/must-not-use-nullish-coalescing-empty-string.d.ts +3 -0
- package/packages/flint/rules/must-not-use-nullish-coalescing-empty-string.js +7 -0
- package/packages/flint/rules/must-not-use-placeholders-in-eslint-rule-titles.js +1 -1
- package/packages/flint/rules/must-not-use-see-link-in-docs-if-type-available.js +2 -1
- package/packages/flint/rules/must-separate-unrelated-tests-into-different-files.js +2 -1
- package/packages/flint/rules/must-specify-second-generic-parameter-in-apipost-and-apiput.js +2 -2
- package/packages/flint/rules/must-use-color-variables-instead-of-hardcoded-values.js +2 -1
- package/packages/flint/rules/must-use-functions-for-component-ids.js +3 -2
- package/packages/flint/rules/must-use-odata-builder.js +2 -1
- package/packages/flint/rules/must-use-only-crud-operations.js +2 -1
- package/packages/flint/rules/must-use-resource-provider-functions-to-get-resources-on-server.d.ts +3 -0
- package/packages/flint/rules/must-use-resource-provider-functions-to-get-resources-on-server.js +11 -0
- package/packages/flint/rules/naming/filename-kebab-case.js +1 -1
- package/packages/flint/rules/naming/must-add-empty-line-before-assert-act-arrange.js +1 -1
- package/packages/flint/rules/naming/must-add-prefix-to-po-functions.js +1 -1
- package/packages/flint/rules/naming/must-avoid-non-null-assertions.js +1 -1
- package/packages/flint/rules/naming/must-create-assert-functions-in-asserts-files.js +1 -1
- package/packages/flint/rules/naming/must-get-elements-in-tests-only-by-id.js +2 -2
- package/packages/flint/rules/naming/must-name-ui-tests-component-condition-expected-result.js +2 -2
- package/packages/flint/rules/naming/must-not-add-files-and-code-in-lib-folder.js +2 -2
- package/packages/flint/rules/naming/must-not-create-funcs-files-for-non-components.js +2 -2
- package/packages/flint/rules/naming/must-not-declare-func-inside-another-func.js +1 -1
- package/packages/flint/rules/naming/must-not-import-react.js +3 -3
- package/packages/flint/rules/naming/must-not-use-emojis.js +1 -1
- package/packages/flint/rules/naming/must-not-use-indexed-access-type-in-function-params.js +1 -1
- package/packages/flint/rules/naming/must-not-use-location-href.js +2 -2
- package/packages/flint/rules/naming/must-not-use-negation-with-enums.js +1 -1
- package/packages/flint/rules/naming/must-not-use-null.js +1 -1
- package/packages/flint/rules/naming/must-not-use-page-directly.d.ts +3 -0
- package/packages/flint/rules/naming/must-not-use-page-directly.js +7 -0
- package/packages/flint/rules/naming/must-not-use-po-in-assert-functions.js +1 -1
- package/packages/flint/rules/naming/must-not-use-redundant-string.js +1 -1
- package/packages/flint/rules/naming/must-not-use-ternary-operator-for-complicated-conditions.js +1 -1
- package/packages/flint/rules/naming/must-put-empty-line.js +1 -1
- package/packages/flint/rules/naming/must-throw-full-error-objects.js +1 -1
- package/packages/flint/rules/naming/must-use-camelcase-for-html-items-id-attribute.js +1 -1
- package/packages/flint/rules/naming/must-use-descriptive-names-for-functions-and-parameters.js +1 -1
- package/packages/flint/rules/naming/must-use-env-keys-from-constant.js +1 -1
- package/packages/flint/rules/naming/must-use-example-domain.js +1 -1
- package/packages/flint/rules/naming/must-use-filename-in-assert-functions.js +1 -1
- package/packages/flint/rules/naming/must-use-func-declaration-for-named-func.js +1 -1
- package/packages/flint/rules/naming/must-use-funcs-only-for-same-named-component.d.ts +3 -0
- package/packages/flint/rules/naming/must-use-funcs-only-for-same-named-component.js +7 -0
- package/packages/flint/rules/naming/must-use-function-for-component.js +1 -1
- package/packages/flint/rules/naming/must-use-interface-for-props.js +2 -2
- package/packages/flint/rules/naming/must-use-new-url-constructor.js +2 -2
- package/packages/flint/rules/naming/must-use-pascal-case-for-types-and-interfaces.js +1 -1
- package/packages/flint/rules/naming/must-use-plural-enum-const-and-singular-type.js +2 -2
- package/packages/flint/rules/naming/must-use-plural-in-function-names-if-returns-array.js +3 -3
- package/packages/flint/rules/naming/must-use-plural-names-of-files-for-arrays.js +3 -3
- package/packages/flint/rules/naming/must-use-resource-name-instead-of-resource.js +1 -1
- package/packages/flint/rules/naming/must-use-s-ending-for-natural-plurals.js +2 -2
- package/packages/flint/rules/naming/must-use-the-fd-prefix-for-env-variables.js +1 -1
- package/packages/flint/rules/naming/must-use-wrappers-to-access-first-element.js +1 -1
- package/packages/flint/rules/naming/no-conflicting-props.js +1 -1
- package/packages/flint/rules/naming/no-default-props.js +1 -1
- package/packages/flint/rules/naming/no-delays-in-ui-tests.js +1 -1
- package/packages/flint/rules/naming/no-fd-prefix-in-folders.js +2 -2
- package/packages/flint/rules/naming/no-get-in-function-names-without-return.js +1 -1
- package/packages/flint/rules/naming/no-integers-instead-of-enums.js +2 -2
- package/packages/flint/rules/naming/no-nullable-check.js +1 -1
- package/packages/flint/rules/naming/no-untyped-objects-between-components.js +2 -2
- package/packages/flint/rules/naming/no-use-conditional-logic-in-test-assertions.js +1 -1
- package/packages/flint/rules/naming/no-use-enum.js +1 -1
- package/packages/flint/rules/naming/no-use-id.js +1 -1
- package/packages/flint/rules/naming/no-utils-helpers-naming.js +2 -2
- package/packages/flint/rules/naming/use-on-prefix.js +2 -2
- package/packages/flint/rules/no-manual-resource-instantiation.d.ts +3 -0
- package/packages/flint/rules/no-manual-resource-instantiation.js +9 -0
- package/packages/flint/rules/performance/must-clean-up-event-listeners.js +1 -1
- package/packages/flint/rules/readability/component-function-max-lines.js +1 -1
- package/packages/flint/rules/readability/exported-func-above-regular.js +1 -1
- package/packages/flint/rules/readability/for-each-max-lines.js +1 -1
- package/packages/flint/rules/readability/max-lines-per-function.js +1 -1
- package/packages/flint/rules/readability/must-consolidate-conditional-expressions.js +1 -1
- package/packages/flint/rules/readability/must-do-await-data-in-one-line.js +1 -1
- package/packages/flint/rules/readability/must-limit-lines-without-comments.js +1 -1
- package/packages/flint/rules/readability/must-not-destructure-function-parameters.js +1 -1
- package/packages/flint/rules/readability/must-not-use-empty-lines-in-html.js +1 -1
- package/packages/flint/rules/readability/must-not-use-inline-await.js +1 -1
- package/packages/flint/rules/readability/must-return-empty-array.js +1 -1
- package/packages/flint/rules/readability/must-use-alt-to-describe-images.js +1 -1
- package/packages/flint/rules/readability/must-use-create-error.js +1 -1
- package/packages/flint/rules/readability/must-use-interfaces-for-complex-types.js +1 -1
- package/packages/flint/rules/readability/must-use-single-return-in-function.js +1 -1
- package/packages/flint/rules/readability/must-use-test-comments.js +1 -1
- package/packages/flint/rules/readability/no-centralized-error-messages.js +1 -1
- package/packages/flint/rules/readability/no-constructor-name-for-resource.js +1 -1
- package/packages/flint/rules/readability/no-long-filter-map.js +1 -1
- package/packages/flint/rules/readability/no-naked-query-return.js +1 -1
- package/packages/flint/rules/readability/no-string-length-check.js +1 -1
- package/packages/flint/rules/readability/no-then.js +1 -1
- package/packages/flint/rules/readability/no-to-lower-case-with-resource-name.js +1 -1
- package/packages/flint/rules/readability/no-useless-destructing.js +1 -1
- package/packages/flint/rules/readability/use-function-without-parameter-shortcut.js +1 -1
- package/packages/flint/rules/readability/use-nullish-coalescing-for-default.js +2 -2
- package/packages/infra/ci/ci-configs.d.ts +7 -0
- package/packages/infra/ci/ci-configs.js +7 -0
- package/packages/infra/ci/constants/ci-constants.d.ts +7 -2
- package/packages/infra/ci/constants/ci-constants.js +2 -1
- package/packages/infra/ci/constants/git-commands.d.ts +2 -0
- package/packages/infra/ci/constants/git-commands.js +1 -1
- package/packages/infra/ci/constants/job-constants.d.ts +1 -0
- package/packages/infra/ci/constants/job-constants.js +3 -2
- package/packages/infra/ci/constants/npm-commands.d.ts +12 -3
- package/packages/infra/ci/constants/npm-commands.js +4 -2
- package/packages/infra/ci/constants/paths.js +1 -1
- package/packages/infra/ci/external-jobs/build-and-test.d.ts +2 -0
- package/packages/infra/ci/external-jobs/build-and-test.js +12 -0
- package/packages/infra/ci/external-jobs/lint.d.ts +2 -0
- package/packages/infra/ci/external-jobs/lint.js +17 -0
- package/packages/infra/ci/external-jobs/prepare-environment.d.ts +2 -0
- package/packages/infra/ci/external-jobs/prepare-environment.js +13 -0
- package/packages/infra/ci/jobs/build-and-test.js +2 -1
- package/packages/infra/ci/jobs/build-db-connection-string.js +2 -1
- package/packages/infra/ci/jobs/build-package.js +1 -1
- package/packages/infra/ci/jobs/ci-auto-merge.js +1 -1
- package/packages/infra/ci/jobs/clear-nx-cache.js +3 -1
- package/packages/infra/ci/jobs/cli-create-test.js +4 -2
- package/packages/infra/ci/jobs/deploy-to-vercel.js +3 -2
- package/packages/infra/ci/jobs/drop-all-db.js +2 -2
- package/packages/infra/ci/jobs/lint.js +5 -4
- package/packages/infra/ci/jobs/manual-cleanup.js +1 -1
- package/packages/infra/ci/jobs/pre-action-required-check.d.ts +1 -0
- package/packages/infra/ci/jobs/pre-action-required-check.js +10 -0
- package/packages/infra/ci/jobs/publish-package.js +1 -1
- package/packages/infra/ci/jobs/ranksters-build-and-test.js +2 -1
- package/packages/infra/ci/jobs/saas-kit-test-build-and-test.js +3 -2
- package/packages/infra/ci/jobs/sync-saas-kit-version-to-main.js +2 -2
- package/packages/infra/ci/jobs/unpublish-package.js +2 -2
- package/packages/infra/ci/jobs/update-submodules.js +2 -2
- package/packages/infra/ci/setup/checkout-and-sync-submodules.js +5 -4
- package/packages/infra/ci/setup/cleanup.js +2 -2
- package/packages/infra/ci/setup/clear-nx-cache-environment.js +1 -1
- package/packages/infra/ci/setup/copy-playwright-report.js +3 -3
- package/packages/infra/ci/setup/get-build-package-info.js +1 -1
- package/packages/infra/ci/setup/get-latest-npm-package-info.js +1 -1
- package/packages/infra/ci/setup/init-db.js +1 -1
- package/packages/infra/ci/setup/install-local-saaskit.js +2 -2
- package/packages/infra/ci/setup/npm-auth.js +3 -2
- package/packages/infra/ci/setup/prepare-environment.js +6 -5
- package/packages/infra/ci/setup/prettier.js +2 -1
- package/packages/infra/ci/setup/resolve-and-checkout-submodule-branch.js +3 -2
- package/packages/infra/ci/setup/resolve-main-repo-branch.js +3 -3
- package/packages/infra/ci/setup/rollup-cache-cloud.js +3 -2
- package/packages/infra/ci/setup/setup-submodules.js +4 -2
- package/packages/infra/ci/setup/spawn-background-server.js +2 -2
- package/packages/infra/ci/setup/sync-build-artifacts.js +3 -1
- package/packages/infra/ci/setup/update-workspace-dependencies.js +1 -1
- package/packages/infra/ci/setup/verify-published-version.js +1 -1
- package/packages/infra/ci/submodules-config.js +2 -2
- package/packages/infra/ci/utils/cloud-client.js +2 -1
- package/packages/infra/ci/utils/create-early-infra-error.js +1 -1
- package/packages/infra/ci/utils/exec.d.ts +2 -2
- package/packages/infra/ci/utils/exec.js +1 -1
- package/packages/infra/ci/utils/get-submodule-dir.d.ts +1 -0
- package/packages/infra/ci/utils/get-submodule-dir.js +6 -0
- package/packages/infra/ci/utils/git-command-funcs.js +1 -1
- package/packages/infra/ci/utils/git.d.ts +2 -1
- package/packages/infra/ci/utils/git.js +6 -5
- package/packages/infra/ci/utils/npm-command-funcs.js +2 -2
- package/packages/infra/deploy/cluster/cluster-deploy-setup.js +1 -1
- package/packages/infra/deploy/cluster/deploy-constants.d.ts +0 -4
- package/packages/infra/deploy/cluster/deploy-constants.js +1 -1
- package/packages/infra/git/gitlab/gitlab-constants.d.ts +8 -1
- package/packages/infra/git/gitlab/gitlab-constants.js +4 -2
- package/packages/infra/git/gitlab/gitlab.js +2 -1
- package/packages/infra/git/labels.d.ts +2 -0
- package/packages/infra/git/labels.js +3 -1
- package/packages/infra/git/milestones.d.ts +3 -0
- package/packages/infra/git/milestones.js +4 -0
- package/packages/infra/plugins/dirname-plugin.js +1 -1
- package/packages/infra/tools/git/commit-msg-script.d.ts +1 -0
- package/packages/infra/tools/git/commit-msg-script.js +8 -0
- package/packages/infra/tools/git/pre-commit-script.d.ts +17 -0
- package/packages/infra/tools/git/pre-commit-script.js +14 -0
- package/packages/level2/ai/server/ai-deepinfra.js +1 -1
- package/packages/level2/ai/server/ai-google.js +1 -1
- package/packages/level2/ai/server/ai-groq.js +1 -1
- package/packages/level2/ai/vercel-ai-sdk/ai.js +1 -1
- package/packages/level2/cli/create/configs/next-cli-config.js +1 -1
- package/packages/level2/cli/create/configs/playwright-cli-config.js +1 -1
- package/packages/level2/client/component-configs/configure-default-config.js +1 -1
- package/packages/level2/client/component-configs/edit-resource-configs.js +2 -2
- package/packages/level2/client/component-configs/multi-list-config.js +1 -1
- package/packages/level2/client/component-configs/resource-list-configs.js +2 -2
- package/packages/level2/client/component-configs/workspace-settings-config.js +1 -1
- package/packages/level2/client/components/providers/ClientRootLayout.d.ts +8 -0
- package/packages/level2/client/components/providers/ClientRootLayout.js +27 -0
- package/packages/level2/client/components/providers/Providers.js +2 -2
- package/packages/level2/client/components/subscription-plan/SubscriptionPlan.funcs.d.ts +1 -1
- package/packages/level2/client/components/subscription-plan/SubscriptionPlan.funcs.js +1 -1
- package/packages/level2/client/components/subscription-plan/subscription-plan-config.js +1 -1
- package/packages/level2/client/components/subscription-plan/subscriptions.js +1 -1
- package/packages/level2/client/components/wizard/Wizard.funcs.js +1 -1
- package/packages/level2/client/components/wizard/WizardStepper.funcs.d.ts +10 -0
- package/packages/level2/client/components/wizard/WizardStepper.funcs.js +3 -2
- package/packages/level2/client/components/wizard/WizardStepper.js +35 -42
- package/packages/level2/client/components/wizard/config/wizard-edit-resource-config.js +1 -1
- package/packages/level2/client/components/wizard/fd-wizard-constants.d.ts +5 -0
- package/packages/level2/client/components/wizard/fd-wizard-constants.js +4 -2
- package/packages/level2/client/pages/dashboard-page/DashboardPage.funcs.js +1 -1
- package/packages/level2/client/pages/microsoft-page/MicrosoftPage.funcs.js +1 -1
- package/packages/level2/client/pages/microsoft-page/MicrosoftPage.js +2 -2
- package/packages/level2/client/pages/screenshot-page/TestScreenshotPage.funcs.js +1 -1
- package/packages/level2/client/pages/test-pages/FiltersTestPage.js +2 -2
- package/packages/level2/client/pages/view-page/ViewPage.funcs.js +1 -1
- package/packages/level2/client/payments/change-payment-method-field/ChangePaymentMethodField.funcs.js +1 -1
- package/packages/level2/client/payments/checkout-form/CheckoutForm.funcs.d.ts +4 -4
- package/packages/level2/client/payments/checkout-form/CheckoutForm.funcs.js +3 -2
- package/packages/level2/client/payments/payments.js +1 -1
- package/packages/level2/client/products/reject-action-funcs.js +1 -1
- package/packages/level2/client/website-scan/website-scan-data.js +2 -1
- package/packages/level2/client/website-scan/website-scan-result-social-media.js +2 -2
- package/packages/level2/common/addresses/address-types.d.ts +2 -2
- package/packages/level2/common/addresses/address-types.js +2 -2
- package/packages/level2/common/addresses/address.resource.js +1 -1
- package/packages/level2/common/addresses/country.resource.js +1 -1
- package/packages/level2/common/auth/permissions/permission-constants.d.ts +0 -2
- package/packages/level2/common/auth/permissions/permission-constants.js +5 -1
- package/packages/level2/common/auth/roles/props/role-props.js +2 -1
- package/packages/level2/common/auth/roles/role-ids.d.ts +0 -1
- package/packages/level2/common/auth/roles/role-ids.js +1 -1
- package/packages/level2/common/auth/roles/role-names.js +3 -1
- package/packages/level2/common/customers/customer-props.js +2 -1
- package/packages/level2/common/customers/customer.resource.js +1 -1
- package/packages/level2/common/demo/company.resource.js +1 -1
- package/packages/level2/common/demo/contact.resource.js +1 -1
- package/packages/level2/common/demo/deal.resource.js +1 -1
- package/packages/level2/common/demo/models/props/status-board-item-props.js +2 -1
- package/packages/level2/common/demo/models/props/status-board-props.js +2 -1
- package/packages/level2/common/demo/models/props/status-board-status-props.js +2 -1
- package/packages/level2/common/demo/props/company-props.js +2 -1
- package/packages/level2/common/demo/props/contact-props.js +2 -1
- package/packages/level2/common/demo/props/dashboard-props.js +2 -1
- package/packages/level2/common/demo/props/deal-props.js +2 -1
- package/packages/level2/common/demo/props/report-props.js +2 -1
- package/packages/level2/common/demo/props/ticket-props.js +2 -1
- package/packages/level2/common/demo/ticket.resource.js +1 -1
- package/packages/level2/common/dev/ai-assistent/ai-assistant.resource.js +1 -1
- package/packages/level2/common/dev/constants/user-ids.js +3 -1
- package/packages/level2/common/dev/custom-permission-resource/custom-permission-resource.resource.js +1 -1
- package/packages/level2/common/dev/dev-report.resource.js +1 -1
- package/packages/level2/common/dev/friends/friend.resource.js +1 -1
- package/packages/level2/common/dev/jobs/job.resource.js +1 -1
- package/packages/level2/common/dev/no-permission.resource.js +1 -1
- package/packages/level2/common/dev/persons/dev-greeting.resource.js +1 -1
- package/packages/level2/common/dev/persons/paper-plane.resource.js +1 -1
- package/packages/level2/common/dev/persons/person-to-job.resource.js +1 -1
- package/packages/level2/common/dev/persons/person-to-person.resource.js +1 -1
- package/packages/level2/common/dev/persons/person.resource-ext.js +1 -1
- package/packages/level2/common/dev/persons/person.resource.js +1 -1
- package/packages/level2/common/dev/persons/phone-brand.resource.js +1 -1
- package/packages/level2/common/dev/persons/ping.resource.js +1 -1
- package/packages/level2/common/dev/props/friend-props.js +2 -1
- package/packages/level2/common/dev/props/person-props.js +2 -1
- package/packages/level2/common/dev/singleton-dev-sandbox.resource.js +1 -1
- package/packages/level2/common/fd/fd-meta-toolbox/status-board/status-board.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/forms/form-field-bank.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/forms/form-field-category.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/forms/form-field-submission.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/forms/form-field-to-form-section.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/forms/form-field.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/forms/form-section.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/forms/form-submission.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/forms/form.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/localization/language.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/localization/localization-string.resource.js +1 -1
- package/packages/level2/common/fd/fd-toolbox-web/localization/props/localization-string-props.js +2 -1
- package/packages/level2/common/fd/media/screenshot-constants.d.ts +0 -1
- package/packages/level2/common/fd/media/screenshot-constants.js +1 -1
- package/packages/level2/common/infra/env-setting-keys.d.ts +1 -1
- package/packages/level2/common/infra/env-setting-keys.js +5 -1
- package/packages/level2/common/leads/google-place.resource.js +1 -1
- package/packages/level2/common/leads/lead-category.resource.js +1 -1
- package/packages/level2/common/leads/lead-email.resource.js +1 -1
- package/packages/level2/common/leads/lead-group.resource.js +1 -1
- package/packages/level2/common/leads/lead-to-lead-category.resource.js +1 -1
- package/packages/level2/common/leads/lead-to-lead-group.resource.js +1 -1
- package/packages/level2/common/leads/lead.resource.js +1 -1
- package/packages/level2/common/leads/props/google-place-props.js +2 -1
- package/packages/level2/common/leads/props/lead-category-props.js +2 -1
- package/packages/level2/common/leads/props/lead-email-props.js +2 -1
- package/packages/level2/common/leads/props/lead-group-props.js +2 -1
- package/packages/level2/common/leads/props/lead-props.js +3 -1
- package/packages/level2/common/leads/props/lead-to-lead-category-props.js +2 -1
- package/packages/level2/common/leads/props/lead-to-lead-group-props.js +2 -1
- package/packages/level2/common/models/create-user-input.js +1 -1
- package/packages/level2/common/models/edit-other-user-dto.js +1 -1
- package/packages/level2/common/models/user-created.js +1 -1
- package/packages/level2/common/orders/order-line-props.js +2 -1
- package/packages/level2/common/orders/order-props.js +2 -1
- package/packages/level2/common/orders/order-transaction-props.js +2 -1
- package/packages/level2/common/payments/feature-to-payment-plan.resource.js +1 -1
- package/packages/level2/common/payments/payment.resource.js +1 -1
- package/packages/level2/common/payments/stripe/stripe-constants.d.ts +7 -18
- package/packages/level2/common/payments/stripe/stripe-constants.js +5 -2
- package/packages/level2/common/payments/system-invoice/payment-system-invoice.resource.js +1 -1
- package/packages/level2/common/products/product-category-props.js +2 -1
- package/packages/level2/common/products/product-parameter-props.js +2 -1
- package/packages/level2/common/products/product-parameter.resource.js +1 -1
- package/packages/level2/common/products/product-props.js +2 -1
- package/packages/level2/common/resources/case.resource2.js +1 -1
- package/packages/level2/common/resources/dashboard-report.resource.js +1 -1
- package/packages/level2/common/resources/dashboard.resource.js +1 -1
- package/packages/level2/common/resources/feed-entry.resource.js +1 -1
- package/packages/level2/common/resources/integration-subscription.resource.js +1 -1
- package/packages/level2/common/resources/item.resource.js +1 -1
- package/packages/level2/common/resources/oauth-service.resource.js +1 -1
- package/packages/level2/common/resources/order-line.resource.js +1 -1
- package/packages/level2/common/resources/order-transaction.resource.js +1 -1
- package/packages/level2/common/resources/order.resource.js +1 -1
- package/packages/level2/common/resources/product-category.resource.js +1 -1
- package/packages/level2/common/resources/product-media.resource.js +1 -1
- package/packages/level2/common/resources/product.resource.js +1 -1
- package/packages/level2/common/resources/props/feed-entry-props.js +2 -1
- package/packages/level2/common/resources/props/oauth-service-props.js +2 -1
- package/packages/level2/common/resources/props/system-setting-props.js +2 -1
- package/packages/level2/common/resources/props/workspace-setting-props.js +2 -1
- package/packages/level2/common/resources/search.resource.js +1 -1
- package/packages/level2/common/resources/searchable-resource.resource.js +1 -1
- package/packages/level2/common/resources/system-setting.resource.js +1 -1
- package/packages/level2/common/resources/website-scan-result.resource.js +1 -1
- package/packages/level2/common/resources/workspace-setting.resource.js +1 -1
- package/packages/level2/common/shipment/shipment-provider.resource.js +1 -1
- package/packages/level2/common/shipment/shipment.resource.js +1 -1
- package/packages/level2/common/stores/store-props.js +2 -1
- package/packages/level2/common/stores/store.resource.js +1 -1
- package/packages/level2/common/tutorial/student.resource.js +1 -1
- package/packages/level2/common/tutorial/teacher.resource.d.ts +1 -0
- package/packages/level2/common/tutorial/teacher.resource.js +1 -1
- package/packages/level2/common/website-scan/analytics-scan.js +1 -1
- package/packages/level2/common/website-scan/website-platform-checking.js +1 -1
- package/packages/level2/db/adapters/postgres-adapter.d.ts +1 -0
- package/packages/level2/db/adapters/postgres-adapter.js +7 -3
- package/packages/level2/db/adapters/sqlite-adapter.d.ts +1 -0
- package/packages/level2/db/adapters/sqlite-adapter.js +4 -3
- package/packages/level2/db/constants/db-constants.d.ts +16 -10
- package/packages/level2/db/constants/db-constants.js +6 -2
- package/packages/level2/db/constants/schema-names.d.ts +49 -0
- package/packages/level2/db/constants/schema-names.js +10 -0
- package/packages/level2/db/db-config.d.ts +1 -1
- package/packages/level2/db/db-config.js +3 -3
- package/packages/level2/db/db-connection.d.ts +1 -0
- package/packages/level2/db/db-connection.js +4 -3
- package/packages/level2/db/db-schema.js +1 -1
- package/packages/level2/db/drizzle-queries.js +3 -2
- package/packages/level2/db/guards/db-type-guards.js +4 -1
- package/packages/level2/db/types/db-types.d.ts +11 -4
- package/packages/level2/db/utils/run-migration-command.d.ts +3 -0
- package/packages/level2/db/utils/run-migration-command.js +7 -4
- package/packages/level2/db/utils/schema-table-names.d.ts +3 -0
- package/packages/level2/db/utils/schema-table-names.js +8 -0
- package/packages/level2/enricher/integrations/google-spreadsheet.js +2 -2
- package/packages/level2/fd-app-toolbox/constants/form-constants.d.ts +10 -0
- package/packages/level2/fd-app-toolbox/constants/form-constants.js +4 -0
- package/packages/level2/fd-app-toolbox/constants/web-socket-methods.js +3 -1
- package/packages/level2/fd-app-toolbox/edit-password-form/EditPasswordForm.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/edit-password-form/EditPasswordForm.js +92 -138
- package/packages/level2/fd-app-toolbox/edit-user-form/EditUserForm.funcs.d.ts +14 -12
- package/packages/level2/fd-app-toolbox/edit-user-form/EditUserForm.funcs.js +4 -1
- package/packages/level2/fd-app-toolbox/edit-user-form/EditUserForm.js +4 -3
- package/packages/level2/fd-app-toolbox/edit-user-sheet/EditUserSheet.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/edit-user-sheet/EditUserSheet.js +2 -2
- package/packages/level2/fd-app-toolbox/forgot-password-form/ForgotPasswordForm.funcs.js +2 -1
- package/packages/level2/fd-app-toolbox/forgot-password-form/ForgotPasswordForm.js +3 -3
- package/packages/level2/fd-app-toolbox/forgot-password-form/forgot-password-messages-constants.js +3 -1
- package/packages/level2/fd-app-toolbox/layout/client-layout/client-layout-config.js +2 -2
- package/packages/level2/fd-app-toolbox/layout/client-root/ClientRoot.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/layout/client-root/ClientRoot.js +31 -20
- package/packages/level2/fd-app-toolbox/layout/sidebar/Sidebar.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/layout/sidebar/sidebar-dropdown-menu/SidebarDropdownMenu.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/layout/sidebar/sidebar-dropdown-menu/SidebarDropdownMenu.js +2 -2
- package/packages/level2/fd-app-toolbox/layout/sidebar/sidebar-resource-names-cache.js +1 -1
- package/packages/level2/fd-app-toolbox/layout/toolbar/Toolbar.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/login-form/LoginForm.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/login-form/LoginForm.js +7 -5
- package/packages/level2/fd-app-toolbox/login-form/facebook-login.js +6 -3
- package/packages/level2/fd-app-toolbox/login-form/google-login.d.ts +1 -0
- package/packages/level2/fd-app-toolbox/login-form/google-login.js +5 -3
- package/packages/level2/fd-app-toolbox/login-form/microsoft-login.d.ts +6 -2
- package/packages/level2/fd-app-toolbox/login-form/microsoft-login.js +7 -4
- package/packages/level2/fd-app-toolbox/login-form/standard-login.js +1 -1
- package/packages/level2/fd-app-toolbox/menu/notifications-menu/NotificationMenu.funcs.js +2 -2
- package/packages/level2/fd-app-toolbox/menu/notifications-menu/notification-list/NotificationList.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/menu/themes.d.ts +1 -0
- package/packages/level2/fd-app-toolbox/menu/themes.js +3 -1
- package/packages/level2/fd-app-toolbox/menu/top-menu/top-menu-item/TopMenuItem.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/menu/user-dropdown-menu/UserDropdownMenu.d.ts +30 -5
- package/packages/level2/fd-app-toolbox/menu/user-dropdown-menu/UserDropdownMenu.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/menu/user-dropdown-menu/user-dropdown-menu-item/UserDropdownMenuItem.d.ts +17 -8
- package/packages/level2/fd-app-toolbox/menu/user-dropdown-menu/user-dropdown-menu-item/UserDropdownMenuItem.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/menu/visible-workspace-picker/VisibleWorkspacePicker.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/menu/workspace-picker/WorkspacePicker.funcs.d.ts +1 -1
- package/packages/level2/fd-app-toolbox/menu/workspace-picker/WorkspacePicker.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/menu/workspace-picker/WorkspacePicker.js +10 -9
- package/packages/level2/fd-app-toolbox/models/screens-result.js +1 -1
- package/packages/level2/fd-app-toolbox/models/searchable-resource-result.js +1 -1
- package/packages/level2/fd-app-toolbox/passwords/edit-password-dto.js +2 -1
- package/packages/level2/fd-app-toolbox/passwords/passwords-api.js +1 -1
- package/packages/level2/fd-app-toolbox/passwords/reset-password-dto.d.ts +0 -4
- package/packages/level2/fd-app-toolbox/passwords/reset-password-dto.js +1 -4
- package/packages/level2/fd-app-toolbox/providers/ThemeProvider/theme.js +2 -1
- package/packages/level2/fd-app-toolbox/register-form/RegisterForm.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/register-form/RegisterForm.js +10 -8
- package/packages/level2/fd-app-toolbox/report/Chart.d.ts +1 -1
- package/packages/level2/fd-app-toolbox/report/Chart.js +130 -121
- package/packages/level2/fd-app-toolbox/report/ReportCard.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/report/ReportChart.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/report/ReportComponent.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/reports/dashboard-report-data.resource.js +1 -1
- package/packages/level2/fd-app-toolbox/reports/report-chart-series.resource.js +1 -1
- package/packages/level2/fd-app-toolbox/reports/report-with-data.resource.js +1 -1
- package/packages/level2/fd-app-toolbox/reports/report.resource.js +1 -1
- package/packages/level2/fd-app-toolbox/reset-password-form/ResetPasswordForm.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/reset-password-form/ResetPasswordForm.js +9 -8
- package/packages/level2/fd-app-toolbox/resources/notification/notification.resource.js +1 -1
- package/packages/level2/fd-app-toolbox/resources/status-board/status-board-item.resource.js +1 -1
- package/packages/level2/fd-app-toolbox/resources/status-board/status-board-status.resource.js +1 -1
- package/packages/level2/fd-app-toolbox/search/Search.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/search/search-dialog/SearchDialog.d.ts +7 -1
- package/packages/level2/fd-app-toolbox/search/search-dialog/SearchDialog.funcs.js +3 -2
- package/packages/level2/fd-app-toolbox/search/search-result/SearchResult.d.ts +4 -1
- package/packages/level2/fd-app-toolbox/search/search-result/SearchResult.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/search/search-searchable-resource-results/SearchSearchableResourceResult.d.ts +10 -7
- package/packages/level2/fd-app-toolbox/search/search-searchable-resource-results/SearchSearchableResourceResult.funcs.d.ts +1 -1
- package/packages/level2/fd-app-toolbox/search/search-searchable-resource-results/SearchSearchableResourceResult.funcs.js +2 -1
- package/packages/level2/fd-app-toolbox/search/search-searchable-resource-results/SearchSearchableResourceResults.d.ts +15 -7
- package/packages/level2/fd-app-toolbox/server/base-resources/props/fill-base-resource-props.js +1 -1
- package/packages/level2/fd-app-toolbox/server/base-resources/props/fill-workspace-resource-props.js +1 -1
- package/packages/level2/fd-app-toolbox/server/infra/workspaces/workspace-db.d.ts +2 -1
- package/packages/level2/fd-app-toolbox/server/infra/workspaces/workspace-db.js +1 -1
- package/packages/level2/fd-app-toolbox/server/layout/sidebar/sidebar-resources.js +1 -1
- package/packages/level2/fd-app-toolbox/server/layout/signed-in-layout/SignedInLayout.js +2 -2
- package/packages/level2/fd-app-toolbox/server/users/user-db.js +1 -1
- package/packages/level2/fd-app-toolbox/server/workspace/visible-workspaces.js +1 -1
- package/packages/level2/fd-app-toolbox/services/web-socket-client.js +1 -1
- package/packages/level2/fd-app-toolbox/status-board/StatusBoard.funcs.js +1 -1
- package/packages/level2/fd-app-toolbox/user-dto.d.ts +0 -1
- package/packages/level2/fd-app-toolbox/user-dto.js +5 -1
- package/packages/level2/fd-app-toolbox/user-list/UserList.d.ts +1 -0
- package/packages/level2/fd-app-toolbox/user-list/UserList.funcs.js +2 -2
- package/packages/level2/fd-app-toolbox/user-list/UserList.js +3 -3
- package/packages/level2/fd-component-toolbox/animation/LabelAnimation.d.ts +3 -9
- package/packages/level2/fd-component-toolbox/animation/LabelAnimation.js +3 -2
- package/packages/level2/fd-component-toolbox/avatar/Avatar.d.ts +9 -6
- package/packages/level2/fd-component-toolbox/avatar/Avatar.js +1 -1
- package/packages/level2/fd-component-toolbox/back-button/BackButton.d.ts +3 -3
- package/packages/level2/fd-component-toolbox/badge-toggle-list/BadgeToggleList.funcs.js +1 -1
- package/packages/level2/fd-component-toolbox/big-calendar/BigCalendar.funcs.js +3 -2
- package/packages/level2/fd-component-toolbox/button/Button.d.ts +18 -14
- package/packages/level2/fd-component-toolbox/button/Button.funcs.js +1 -1
- package/packages/level2/fd-component-toolbox/button/Button.js +60 -117
- package/packages/level2/fd-component-toolbox/calendar/Calendar.d.ts +4 -6
- package/packages/level2/fd-component-toolbox/calendar/Calendar.funcs.js +1 -1
- package/packages/level2/fd-component-toolbox/calendar/Calendar.js +3 -2
- package/packages/level2/fd-component-toolbox/calendar/calendar-constants.js +4 -1
- package/packages/level2/fd-component-toolbox/client/framework/index.js +3 -3
- package/packages/level2/fd-component-toolbox/datepicker/DatePicker.d.ts +13 -13
- package/packages/level2/fd-component-toolbox/datepicker/DatePicker.funcs.js +2 -2
- package/packages/level2/fd-component-toolbox/dialog/YesOrNoDialog.funcs.js +1 -1
- package/packages/level2/fd-component-toolbox/drag-and-drop/DragDropContext.d.ts +1 -1
- package/packages/level2/fd-component-toolbox/drag-and-drop/Draggable.js +7 -2
- package/packages/level2/fd-component-toolbox/drag-and-drop/Droppable.d.ts +1 -1
- package/packages/level2/fd-component-toolbox/dropdown-menu/DropdownMenu.d.ts +38 -15
- package/packages/level2/fd-component-toolbox/dynamic-layout/DynamicLayoutDragAndDrop.d.ts +8 -3
- package/packages/level2/fd-component-toolbox/dynamic-layout/DynamicLayoutDragAndDrop.funcs.d.ts +1 -1
- package/packages/level2/fd-component-toolbox/dynamic-layout/DynamicLayoutDragAndDrop.funcs.js +3 -2
- package/packages/level2/fd-component-toolbox/fade-out-text/FadeOutText.d.ts +12 -12
- package/packages/level2/fd-component-toolbox/fade-out-text/FadeOutText.funcs.js +1 -1
- package/packages/level2/fd-component-toolbox/fade-out-text/FadeOutText.js +3 -2
- package/packages/level2/fd-component-toolbox/form/Form.d.ts +2 -2
- package/packages/level2/fd-component-toolbox/image-radio-group/ImageRadioGroup.js +2 -2
- package/packages/level2/fd-component-toolbox/input/Input.d.ts +29 -10
- package/packages/level2/fd-component-toolbox/input/Input.funcs.js +1 -1
- package/packages/level2/fd-component-toolbox/input/Input.js +10 -7
- package/packages/level2/fd-component-toolbox/label/Label.d.ts +3 -2
- package/packages/level2/fd-component-toolbox/label/Label.js +3 -2
- package/packages/level2/fd-component-toolbox/label/label-constants.d.ts +6 -0
- package/packages/level2/fd-component-toolbox/label/label-constants.js +4 -0
- package/packages/level2/fd-component-toolbox/list/list-item/ListItem.funcs.js +3 -1
- package/packages/level2/fd-component-toolbox/list/list-item/ListItem.js +2 -2
- package/packages/level2/fd-component-toolbox/markdown/Markdown.funcs.js +1 -1
- package/packages/level2/fd-component-toolbox/markdown/Markdown.js +5 -4
- package/packages/level2/fd-component-toolbox/markdown/markdown-parser.js +4 -2
- package/packages/level2/fd-component-toolbox/multiselect/Multiselect.d.ts +2 -2
- package/packages/level2/fd-component-toolbox/multiselect/Multiselect.funcs.js +2 -1
- package/packages/level2/fd-component-toolbox/multiselect/Multiselect.js +2 -1
- package/packages/level2/fd-component-toolbox/multiselect/hooks/use-multi-select.js +1 -1
- package/packages/level2/fd-component-toolbox/navigation/Navigation.d.ts +7 -7
- package/packages/level2/fd-component-toolbox/navigation/navigation-item/NavigationItem.d.ts +6 -1
- package/packages/level2/fd-component-toolbox/navigation/navigation-item/NavigationItem.funcs.js +3 -1
- package/packages/level2/fd-component-toolbox/rich-text/RichText.funcs.js +3 -3
- package/packages/level2/fd-component-toolbox/rich-text/rich-text-constants.js +4 -1
- package/packages/level2/fd-component-toolbox/save-status/SaveStatus.d.ts +10 -5
- package/packages/level2/fd-component-toolbox/save-status/SaveStatus.js +3 -3
- package/packages/level2/fd-component-toolbox/select/Select.d.ts +21 -18
- package/packages/level2/fd-component-toolbox/select/Select.js +11 -8
- package/packages/level2/fd-component-toolbox/sheet/Sheet.js +4 -5
- package/packages/level2/fd-component-toolbox/sizing/sizing.js +2 -1
- package/packages/level2/fd-component-toolbox/slide-toggle/SlideToggle.d.ts +14 -9
- package/packages/level2/fd-component-toolbox/slide-toggle/SlideToggle.js +3 -2
- package/packages/level2/fd-component-toolbox/spinner/Spinner.d.ts +2 -1
- package/packages/level2/fd-component-toolbox/spinner/Spinner.js +6 -3
- package/packages/level2/fd-component-toolbox/switch/Switch.funcs.js +1 -1
- package/packages/level2/fd-component-toolbox/table-element-suffixes.js +4 -1
- package/packages/level2/fd-component-toolbox/textarea/TextArea.funcs.js +1 -1
- package/packages/level2/fd-component-toolbox/toaster/Toaster.funcs.js +1 -1
- package/packages/level2/fd-component-toolbox/tooltip/Tooltip.d.ts +3 -3
- package/packages/level2/fd-component-toolbox/tooltip/Tooltip.js +3 -3
- package/packages/level2/meta/api/hooks/use-ui-resource-meta.js +1 -1
- package/packages/level2/meta/api/meta-odata.js +1 -1
- package/packages/level2/meta/auth/auth-guards.js +1 -1
- package/packages/level2/meta/auth/auth-handler.js +1 -1
- package/packages/level2/meta/auth/login.js +2 -1
- package/packages/level2/meta/auth/logins.js +3 -1
- package/packages/level2/meta/auth/permissions/permission-checker.js +1 -1
- package/packages/level2/meta/browsers/base-multi-browser/BaseMultiBrowser.funcs.js +1 -1
- package/packages/level2/meta/browsers/base-multi-browser/base-multi-browser-dialog/BaseMultiBrowserDialog.funcs.js +2 -2
- package/packages/level2/meta/browsers/browser/Browser.funcs.js +1 -1
- package/packages/level2/meta/browsers/browser/browser-dialog/BrowserDialog.funcs.js +1 -1
- package/packages/level2/meta/browsers/browser-type.d.ts +1 -0
- package/packages/level2/meta/browsers/browser-type.js +4 -1
- package/packages/level2/meta/browsers/many-to-many-browser/ManyToManyBrowser.funcs.js +1 -1
- package/packages/level2/meta/browsers/multi-browser/MultiBrowser.funcs.js +1 -1
- package/packages/level2/meta/card-list/CardList.funcs.js +1 -1
- package/packages/level2/meta/card-list/card-models.d.ts +2 -2
- package/packages/level2/meta/card-list/config/card-config.js +1 -1
- package/packages/level2/meta/card-list/data-card/DataCard.funcs.js +1 -1
- package/packages/level2/meta/card-list/data-card/data-card-content/DataCardContent.funcs.d.ts +1 -2
- package/packages/level2/meta/card-list/data-card/data-card-content/DataCardContent.funcs.js +2 -1
- package/packages/level2/meta/card-list/data-card/data-card-content/DataCardContent.js +3 -79
- package/packages/level2/meta/card-list/data-card/data-card-content/DataCardContent.render.funcs.d.ts +4 -0
- package/packages/level2/meta/card-list/data-card/data-card-content/DataCardContent.render.funcs.js +86 -0
- package/packages/level2/meta/client/framework/hooks.js +2 -1
- package/packages/level2/meta/client/framework/index.js +1 -1
- package/packages/level2/meta/client/layout.js +1 -1
- package/packages/level2/meta/comment/Comment.js +2 -2
- package/packages/level2/meta/comment/CommentList.d.ts +5 -5
- package/packages/level2/meta/comment/CommentList.funcs.js +2 -2
- package/packages/level2/meta/components/edit-image/EditImage.funcs.js +1 -1
- package/packages/level2/meta/components/edit-image/EditImageActionMenu.js +6 -5
- package/packages/level2/meta/components/edit-image/EditImageDropdownMenu.js +6 -5
- package/packages/level2/meta/components/file-upload/FileUpload.d.ts +1 -8
- package/packages/level2/meta/components/file-upload/FileUpload.funcs.js +2 -1
- package/packages/level2/meta/components/multi-list/MultiList.d.ts +17 -11
- package/packages/level2/meta/components/multi-list/MultiList.funcs.js +1 -1
- package/packages/level2/meta/components/multi-list/MultiList.js +15 -12
- package/packages/level2/meta/components/multi-list/MultiListEditResource.d.ts +10 -1
- package/packages/level2/meta/components/multi-list/multi-list-constants.d.ts +6 -0
- package/packages/level2/meta/components/multi-list/multi-list-constants.js +4 -0
- package/packages/level2/meta/components/multi-list/multi-list-types.d.ts +5 -4
- package/packages/level2/meta/components/multi-list/multi-list-types.js +2 -2
- package/packages/level2/meta/components/multi-list/use-multi-list-edit-resource-config.js +1 -1
- package/packages/level2/meta/components/related-resources/RelatedResources.funcs.js +1 -1
- package/packages/level2/meta/components/related-resources/related-property.js +1 -1
- package/packages/level2/meta/components/related-resources/related-resources-component.js +1 -1
- package/packages/level2/meta/components/user-settings/RolesSettingsLinks.d.ts +2 -1
- package/packages/level2/meta/components/user-settings/RolesSettingsLinks.js +4 -1
- package/packages/level2/meta/constants/image-action-labels.d.ts +6 -0
- package/packages/level2/meta/constants/image-action-labels.js +6 -0
- package/packages/level2/meta/constants/meta-error-messages-constants.js +10 -1
- package/packages/level2/meta/constants/property-type-formats.d.ts +0 -3
- package/packages/level2/meta/constants/property-type-formats.js +5 -1
- package/packages/level2/meta/constants/relation-action-labels.d.ts +4 -0
- package/packages/level2/meta/constants/relation-action-labels.js +4 -0
- package/packages/level2/meta/constants/toolbox-users.js +1 -1
- package/packages/level2/meta/constants/user-names.d.ts +0 -8
- package/packages/level2/meta/constants/user-names.js +2 -2
- package/packages/level2/meta/core/auth-resource-meta.js +1 -1
- package/packages/level2/meta/core/property-meta.js +1 -1
- package/packages/level2/meta/core/property-types.js +1 -1
- package/packages/level2/meta/core/relation.js +1 -1
- package/packages/level2/meta/core/resource-description/resource-description.js +1 -1
- package/packages/level2/meta/core/resource-description/resource-descriptions.js +2 -1
- package/packages/level2/meta/core/resource-meta.js +1 -1
- package/packages/level2/meta/core/resource-singletons.js +1 -1
- package/packages/level2/meta/core/resources/blob/blob-urls.js +1 -1
- package/packages/level2/meta/core/resources/blob/blob.resource.js +1 -1
- package/packages/level2/meta/core/resources/comment.resource.js +1 -1
- package/packages/level2/meta/core/resources/features/feature.resource.js +1 -1
- package/packages/level2/meta/core/resources/payment-plan-feature.resource.js +1 -1
- package/packages/level2/meta/core/resources/payment-plan.resource.js +1 -1
- package/packages/level2/meta/core/resources/permissions/permission-package-to-permission.resource.js +1 -1
- package/packages/level2/meta/core/resources/permissions/permission-package.resource.js +1 -1
- package/packages/level2/meta/core/resources/pricing.resource.js +1 -1
- package/packages/level2/meta/core/resources/resources/resource-property.resource.js +1 -1
- package/packages/level2/meta/core/resources/resources/resource.resource.js +1 -1
- package/packages/level2/meta/core/resources/roles/role-feature.resource.js +1 -1
- package/packages/level2/meta/core/resources/roles/role-to-permission-package.resource.js +1 -1
- package/packages/level2/meta/core/resources/roles/role-to-permission.resource.js +1 -1
- package/packages/level2/meta/core/resources/roles/role.resource.js +1 -1
- package/packages/level2/meta/core/resources/usage-limit/usage-limit.resource.js +1 -1
- package/packages/level2/meta/core/resources/users/user-activity-overview.resource.js +1 -1
- package/packages/level2/meta/core/resources/users/user-feature.resource.js +1 -1
- package/packages/level2/meta/core/resources/users/user-role.resource.js +1 -1
- package/packages/level2/meta/core/resources/users/user-setting.resource.js +1 -1
- package/packages/level2/meta/core/resources/users/user-to-workspace.resource.js +1 -1
- package/packages/level2/meta/core/resources/users/user-visible-workspace.resource.js +1 -1
- package/packages/level2/meta/core/resources/users/user-workspace-invite.resource.js +1 -1
- package/packages/level2/meta/core/resources/users/user.resource.js +1 -1
- package/packages/level2/meta/core/resources/workspace/workspace-resource.js +1 -1
- package/packages/level2/meta/core/resources/workspace/workspace-to-workspace.resource.js +1 -1
- package/packages/level2/meta/core/resources/workspace/workspace.resource.js +1 -1
- package/packages/level2/meta/core/ui-property-meta-old.js +1 -1
- package/packages/level2/meta/crud/permissions/crud-permission-checker.js +1 -1
- package/packages/level2/meta/decorators/access-by-user-id.js +1 -1
- package/packages/level2/meta/decorators/access-by-workspace-id.js +1 -1
- package/packages/level2/meta/decorators/allowed-crud-actions.js +1 -1
- package/packages/level2/meta/decorators/big-text.js +1 -1
- package/packages/level2/meta/decorators/blob-image.js +1 -1
- package/packages/level2/meta/decorators/colorful.js +1 -1
- package/packages/level2/meta/decorators/concat-description.js +1 -1
- package/packages/level2/meta/decorators/create-only-resource.js +1 -1
- package/packages/level2/meta/decorators/currency.js +1 -1
- package/packages/level2/meta/decorators/date-only.js +1 -1
- package/packages/level2/meta/decorators/db-index.js +1 -1
- package/packages/level2/meta/decorators/default-sort.js +1 -1
- package/packages/level2/meta/decorators/description-based-on-property-value.js +1 -1
- package/packages/level2/meta/decorators/description-property.js +1 -1
- package/packages/level2/meta/decorators/display-name.js +1 -1
- package/packages/level2/meta/decorators/dynamic.js +1 -1
- package/packages/level2/meta/decorators/email.js +1 -1
- package/packages/level2/meta/decorators/expand-description-properties.js +1 -1
- package/packages/level2/meta/decorators/file-upload.js +1 -1
- package/packages/level2/meta/decorators/flags-enum.js +1 -1
- package/packages/level2/meta/decorators/get-only-resource.js +1 -1
- package/packages/level2/meta/decorators/icon.d.ts +2 -0
- package/packages/level2/meta/decorators/icon.js +1 -1
- package/packages/level2/meta/decorators/integer.js +1 -1
- package/packages/level2/meta/decorators/label.js +1 -1
- package/packages/level2/meta/decorators/markdown.js +1 -1
- package/packages/level2/meta/decorators/not-a-resource.js +1 -1
- package/packages/level2/meta/decorators/not-colorful.js +1 -1
- package/packages/level2/meta/decorators/not-displayable.js +1 -1
- package/packages/level2/meta/decorators/not-edit-displayable.js +1 -1
- package/packages/level2/meta/decorators/not-editable-from-outside.js +1 -1
- package/packages/level2/meta/decorators/not-filter-displayable.js +1 -1
- package/packages/level2/meta/decorators/not-list-displayable.js +1 -1
- package/packages/level2/meta/decorators/not-relation.js +1 -1
- package/packages/level2/meta/decorators/outside-excluded.js +1 -1
- package/packages/level2/meta/decorators/permission-checker-for.d.ts +10 -8
- package/packages/level2/meta/decorators/permission-checker-for.js +2 -3
- package/packages/level2/meta/decorators/phone-number.js +1 -1
- package/packages/level2/meta/decorators/plural-name.js +1 -1
- package/packages/level2/meta/decorators/prefer-plural-name.js +1 -1
- package/packages/level2/meta/decorators/prefer-singular-name.js +1 -1
- package/packages/level2/meta/decorators/priority.js +1 -1
- package/packages/level2/meta/decorators/required-if-other-are-present.js +1 -1
- package/packages/level2/meta/decorators/required-if-prop-has-value.js +1 -1
- package/packages/level2/meta/decorators/required.js +1 -1
- package/packages/level2/meta/decorators/resource-id.js +1 -1
- package/packages/level2/meta/decorators/resource-property-id.js +1 -1
- package/packages/level2/meta/decorators/rich-text.js +1 -1
- package/packages/level2/meta/decorators/searchable.js +1 -1
- package/packages/level2/meta/decorators/singleton.js +1 -1
- package/packages/level2/meta/decorators/transient-resource.js +1 -1
- package/packages/level2/meta/decorators/ui-priority.js +1 -1
- package/packages/level2/meta/decorators/ui-relation-priority.js +1 -1
- package/packages/level2/meta/decorators/unique.js +1 -1
- package/packages/level2/meta/decorators/url.js +1 -1
- package/packages/level2/meta/edit-resource/EditResource.funcs.d.ts +3 -1
- package/packages/level2/meta/edit-resource/EditResource.funcs.js +2 -2
- package/packages/level2/meta/edit-resource/EditResource.js +13 -9
- package/packages/level2/meta/edit-resource/EditResourceHeader.funcs.js +1 -1
- package/packages/level2/meta/edit-resource/EditResourceSheet.d.ts +7 -9
- package/packages/level2/meta/edit-resource/EditResourceSheet.funcs.js +1 -1
- package/packages/level2/meta/edit-resource/EditResourceTabs.funcs.js +2 -2
- package/packages/level2/meta/edit-resource/apply-value-changes.js +1 -1
- package/packages/level2/meta/edit-resource/config/custom-filter-config-provider.js +1 -1
- package/packages/level2/meta/edit-resource/config/edit-resource-configs.d.ts +1 -0
- package/packages/level2/meta/edit-resource/config/edit-resource-configs.js +6 -3
- package/packages/level2/meta/edit-resource/edit-link/EditLink.funcs.js +1 -1
- package/packages/level2/meta/edit-resource/edit-resource-constants.d.ts +2 -2
- package/packages/level2/meta/edit-resource/edit-resource-constants.js +3 -1
- package/packages/level2/meta/edit-resource/edit-resource-dialog/EditResourceDialog.funcs.js +1 -1
- package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourceBlobField.funcs.js +1 -1
- package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourceEnumField.funcs.js +1 -1
- package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourceFlagsEnumField.funcs.js +1 -1
- package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourceImageField.funcs.js +1 -1
- package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourcePropertyBlock.d.ts +1 -1
- package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourcePropertyBlock.funcs.js +1 -1
- package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourcePropertyBlock.js +2 -1
- package/packages/level2/meta/edit-resource/edit-resource-property-field/EditResourcePropertyField.funcs.js +1 -1
- package/packages/level2/meta/edit-resource/edit-resource-validation.js +1 -1
- package/packages/level2/meta/edit-resource/edit-resources-constants.js +1 -1
- package/packages/level2/meta/edit-resource/hooks/use-edit-resource-ref.js +1 -1
- package/packages/level2/meta/edit-resource/save-complete-context.js +1 -1
- package/packages/level2/meta/edit-resource/services/blob-components.js +1 -1
- package/packages/level2/meta/edit-resource/services/edit-resource-components.js +1 -1
- package/packages/level2/meta/edit-resource/services/edit-resource-relations.js +1 -1
- package/packages/level2/meta/edit-resource/services/edit-resources.js +1 -1
- package/packages/level2/meta/edit-resource/services/form-validations.js +1 -1
- package/packages/level2/meta/edit-resource/services/property-metas.js +1 -1
- package/packages/level2/meta/edit-resource/services/use-edit-resource-config.js +1 -1
- package/packages/level2/meta/fd-meta-toolbox-service.js +1 -1
- package/packages/level2/meta/filtering/filter/Filter.funcs.js +1 -1
- package/packages/level2/meta/filtering/filter/Filter.js +1 -1
- package/packages/level2/meta/filtering/filter/filter-constants.d.ts +5 -0
- package/packages/level2/meta/filtering/filter/filter-constants.js +2 -2
- package/packages/level2/meta/filtering/filter/filters/boolean-filter/BooleanFilter.funcs.d.ts +10 -4
- package/packages/level2/meta/filtering/filter/filters/boolean-filter/BooleanFilter.funcs.js +6 -1
- package/packages/level2/meta/filtering/filter-list-positions.d.ts +3 -3
- package/packages/level2/meta/filtering/filter-list-positions.js +2 -2
- package/packages/level2/meta/filtering/resource-filter-list/ResourceFilterList.funcs.js +3 -2
- package/packages/level2/meta/filtering/resource-filter-list/ResourceFilterList.js +6 -6
- package/packages/level2/meta/filtering/resource-filter-list/resource-filter-list-ids.js +3 -1
- package/packages/level2/meta/filtering/resource-filter-list/resource-filter-lists.js +1 -1
- package/packages/level2/meta/filtering/resource-filter-list/use-resource-filter-list-display.d.ts +9 -1
- package/packages/level2/meta/filtering/resource-filter-list/use-resource-filter-list-display.js +2 -1
- package/packages/level2/meta/layout/events.js +1 -1
- package/packages/level2/meta/meta-providers.js +1 -1
- package/packages/level2/meta/meta-sort.js +1 -1
- package/packages/level2/meta/models/user-base-resource.js +1 -1
- package/packages/level2/meta/models/user-workspace-base-resource.js +1 -1
- package/packages/level2/meta/odata/expands.js +2 -1
- package/packages/level2/meta/odata/odata-selects.js +2 -2
- package/packages/level2/meta/one-to-many-relations.js +1 -1
- package/packages/level2/meta/page/title-context.d.ts +0 -1
- package/packages/level2/meta/page/title-context.js +3 -2
- package/packages/level2/meta/page/use-set-title.js +1 -1
- package/packages/level2/meta/page/use-title.js +1 -1
- package/packages/level2/meta/relations/many-to-many-info.d.ts +16 -10
- package/packages/level2/meta/relations/many-to-many-info.js +1 -1
- package/packages/level2/meta/relations/meta-relations.js +1 -1
- package/packages/level2/meta/resource-list/ResourceList.d.ts +1 -1
- package/packages/level2/meta/resource-list/ResourceList.funcs.js +7 -4
- package/packages/level2/meta/resource-list/ResourceList.js +3 -2
- package/packages/level2/meta/resource-list/resource-list-cell-element-ids.js +1 -1
- package/packages/level2/meta/resource-list/resource-list-checkers.js +1 -1
- package/packages/level2/meta/resource-list/resource-list-configs.js +2 -2
- package/packages/level2/meta/resource-list/resource-list-header/ResourceListHeader.funcs.js +1 -1
- package/packages/level2/meta/resource-list/resource-list-hooks.js +1 -1
- package/packages/level2/meta/resource-list/resource-list-persist-state.js +1 -1
- package/packages/level2/meta/resource-list/resource-lists.js +1 -1
- package/packages/level2/meta/resource-list/use-resource-list-config.js +1 -1
- package/packages/level2/meta/resource-providers.js +1 -1
- package/packages/level2/meta/resources/session/session.resource.js +1 -1
- package/packages/level2/meta/server/api/odata/odata-expression-operators.js +2 -2
- package/packages/level2/meta/server/api/odata/odata-expressions.js +1 -1
- package/packages/level2/meta/server/api/odata/odata-filters-helpers.js +2 -1
- package/packages/level2/meta/server/api/odata/odata-filters.js +4 -2
- package/packages/level2/meta/server/api/odata/odata-metas.js +2 -2
- package/packages/level2/meta/server/api/odata/odata-parsers.js +3 -4
- package/packages/level2/meta/server/api/odata/odata.js +1 -1
- package/packages/level2/meta/server/auth/auth-guard.js +2 -2
- package/packages/level2/meta/server/auth/fd-sessions.js +1 -1
- package/packages/level2/meta/server/auth/permissions/resource-permission-checker-provider.d.ts +1 -0
- package/packages/level2/meta/server/auth/permissions/resource-permission-checker-provider.js +3 -3
- package/packages/level2/meta/server/auth/role-db/get-all-including-user-to-roles.js +2 -2
- package/packages/level2/meta/server/auth/session-access.js +1 -1
- package/packages/level2/meta/server/auth/session-validation.js +2 -1
- package/packages/level2/meta/server/auth/session.js +1 -1
- package/packages/level2/meta/server/auth/users/current-user-id-provider.js +1 -1
- package/packages/level2/meta/server/basic-crud/crud-api.d.ts +9 -24
- package/packages/level2/meta/server/basic-crud/crud-api.js +2 -3
- package/packages/level2/meta/server/basic-crud/crud.js +2 -1
- package/packages/level2/meta/server/basic-crud/cruds.js +1 -1
- package/packages/level2/meta/server/basic-crud/helpers/crud-event-handler.js +2 -2
- package/packages/level2/meta/server/basic-crud/helpers/cruds-permission-checker.js +1 -1
- package/packages/level2/meta/server/basic-crud/helpers/prepare-many-to-many-resource.js +1 -1
- package/packages/level2/meta/server/basic-crud/related-resource-db.js +1 -1
- package/packages/level2/meta/server/basic-crud/relation-syncs.d.ts +1 -3
- package/packages/level2/meta/server/basic-crud/relation-syncs.js +1 -1
- package/packages/level2/meta/server/basic-crud/resource-crud-handlers.js +1 -1
- package/packages/level2/meta/server/basic-crud/resource-meta-handlers.js +1 -1
- package/packages/level2/meta/server/constants/crud-handler-types.d.ts +1 -1
- package/packages/level2/meta/server/constants/crud-handler-types.js +2 -2
- package/packages/level2/meta/server/constants/generated-paths.d.ts +6 -6
- package/packages/level2/meta/server/constants/generated-paths.js +2 -2
- package/packages/level2/meta/server/constants/meta-property-names.js +5 -1
- package/packages/level2/meta/server/constants/meta-validation-messages.js +3 -1
- package/packages/level2/meta/server/constants/resource-file-suffixes.d.ts +4 -0
- package/packages/level2/meta/server/constants/resource-file-suffixes.js +6 -0
- package/packages/level2/meta/server/controllers/generic-controllers/crud-controller.js +2 -1
- package/packages/level2/meta/server/db/colums-data-types.d.ts +0 -9
- package/packages/level2/meta/server/db/colums-data-types.js +1 -1
- package/packages/level2/meta/server/db/db.js +2 -2
- package/packages/level2/meta/server/db/drizzle-names.d.ts +0 -1
- package/packages/level2/meta/server/db/drizzle-names.js +1 -1
- package/packages/level2/meta/server/db/init-db.js +1 -1
- package/packages/level2/meta/server/db/schema/schema-adapter.d.ts +1 -5
- package/packages/level2/meta/server/db/schema/schema-adapter.js +4 -2
- package/packages/level2/meta/server/entities/edit-base-resources.js +1 -1
- package/packages/level2/meta/server/entities/edit-workspace.js +2 -1
- package/packages/level2/meta/server/integration-platforms/fd-integration-cache.d.ts +1 -1
- package/packages/level2/meta/server/integration-platforms/fd-integration-cache.js +3 -1
- package/packages/level2/meta/server/integration-platforms/integration-db.js +2 -2
- package/packages/level2/meta/server/integration-platforms/integration-events.d.ts +5 -5
- package/packages/level2/meta/server/integration-platforms/integration-events.js +2 -1
- package/packages/level2/meta/server/messaging/messages.js +1 -1
- package/packages/level2/meta/server/meta-core/auth/permissions/resource-permission-checker.d.ts +3 -3
- package/packages/level2/meta/server/meta-core/constants/metas.js +4 -1
- package/packages/level2/meta/server/meta-core/constants/resource-ids.js +1 -1
- package/packages/level2/meta/server/meta-core/crud/crud-handlers.d.ts +8 -8
- package/packages/level2/meta/server/meta-core/crud/crud-handlers.js +1 -1
- package/packages/level2/meta/server/meta-core/crud/crud-update-config.js +1 -1
- package/packages/level2/meta/server/meta-core/crud/search.js +2 -2
- package/packages/level2/meta/server/meta-core/display-name.js +1 -1
- package/packages/level2/meta/server/meta-url-service.js +2 -2
- package/packages/level2/meta/server/models/roles/role-to-permission-package-db.js +1 -1
- package/packages/level2/meta/server/modules/dynamic-imports.js +26 -24
- package/packages/level2/meta/server/modules/handler-map.d.ts +4 -0
- package/packages/level2/meta/server/modules/handler-map.js +26 -0
- package/packages/level2/meta/server/permission/permission-checker.d.ts +1 -0
- package/packages/level2/meta/server/permission/permission-checker.js +2 -2
- package/packages/level2/meta/server/permission/permission-data-provider.d.ts +1 -13
- package/packages/level2/meta/server/permission/permission-data-provider.js +2 -2
- package/packages/level2/meta/server/permission/permission-package-to-permission-db.js +2 -2
- package/packages/level2/meta/server/permission/permissions.js +2 -1
- package/packages/level2/meta/server/permission/user-permissions-builder.js +2 -1
- package/packages/level2/meta/server/props/meta-property-filters.js +1 -1
- package/packages/level2/meta/server/props/property-meta-config-provider.js +1 -1
- package/packages/level2/meta/server/props/property-names.js +1 -1
- package/packages/level2/meta/server/props/required-properties.js +1 -1
- package/packages/level2/meta/server/providers/current-workspace-id-provider.js +1 -1
- package/packages/level2/meta/server/relations/many-to-many-relations.js +1 -1
- package/packages/level2/meta/server/relations/relations.js +1 -1
- package/packages/level2/meta/server/repositories/odata-db.js +1 -1
- package/packages/level2/meta/server/resources/crud-resources.js +1 -1
- package/packages/level2/meta/server/resources/dynamic-properties.js +1 -1
- package/packages/level2/meta/server/resources/init-internal-resource-metas-from-json.js +2 -2
- package/packages/level2/meta/server/resources/internal-resource-meta.js +1 -1
- package/packages/level2/meta/server/resources/resource-checker.d.ts +1 -1
- package/packages/level2/meta/server/resources/resource-checker.js +3 -1
- package/packages/level2/meta/server/resources/resource-meta-plugin-constants.js +3 -1
- package/packages/level2/meta/server/resources/resource-meta-plugin.js +4 -3
- package/packages/level2/meta/server/resources/searchable-resources-api.d.ts +1 -3
- package/packages/level2/meta/server/resources/searchable-resources-api.js +1 -2
- package/packages/level2/meta/server/resources/searchable-resources.js +1 -1
- package/packages/level2/meta/server/services/crud-actions.js +1 -1
- package/packages/level2/meta/server/services/metas.js +1 -1
- package/packages/level2/meta/server/services/permission-check-config-provider.js +1 -1
- package/packages/level2/meta/server/services/property-meta.js +1 -1
- package/packages/level2/meta/server/services/property-metas.js +1 -1
- package/packages/level2/meta/server/services/resource-name-converter.js +1 -1
- package/packages/level2/meta/server/services/resource-provider-db.js +1 -1
- package/packages/level2/meta/server/services/resource-provider-defaults.js +1 -1
- package/packages/level2/meta/server/services/resource-provider-expands.js +1 -1
- package/packages/level2/meta/server/services/resource-provider-permissions.js +1 -1
- package/packages/level2/meta/server/services/resource-provider.js +2 -2
- package/packages/level2/meta/server/ui/meta-api.d.ts +1 -3
- package/packages/level2/meta/server/ui/meta-api.js +1 -2
- package/packages/level2/meta/server/ui/ui-metas-api.d.ts +2 -6
- package/packages/level2/meta/server/ui/ui-metas-api.js +1 -2
- package/packages/level2/meta/server/ui/ui-metas.js +1 -1
- package/packages/level2/meta/server/validations/meta-validations.js +3 -2
- package/packages/level2/meta/server/value-checker.js +2 -2
- package/packages/level2/meta/server/web/current-url.js +1 -1
- package/packages/level2/meta/server/web/drizzle-guards.js +1 -1
- package/packages/level2/meta/server/web/drizzle.js +3 -1
- package/packages/level2/meta/server/web/http-api-wrapper.d.ts +3 -4
- package/packages/level2/meta/server/web/http-api-wrapper.js +2 -3
- package/packages/level2/meta/server/web/init-saas-kit-config.d.ts +9 -0
- package/packages/level2/meta/server/web/init-saas-kit-config.js +8 -0
- package/packages/level2/meta/server/web/reduce-data.js +1 -1
- package/packages/level2/meta/server/web/responses.js +1 -1
- package/packages/level2/meta/server/workspace/get-visible-workspaces-cache-key.js +1 -1
- package/packages/level2/meta/services/client-environment.js +1 -1
- package/packages/level2/meta/services/filter-components.js +1 -1
- package/packages/level2/meta/services/meta-navigations.js +1 -1
- package/packages/level2/meta/services/property-values.d.ts +1 -1
- package/packages/level2/meta/services/property-values.js +3 -3
- package/packages/level2/meta/services/resource-filters.js +2 -2
- package/packages/level2/meta/services/resource-name-client-converter.js +1 -1
- package/packages/level2/meta/services/window.js +3 -1
- package/packages/level2/meta/state/base-state-functions.js +1 -1
- package/packages/level2/meta/subscription-plan/fetch-active-or-trial-subscription.js +1 -1
- package/packages/level2/meta/subscription-plan/subscription.resource.js +1 -1
- package/packages/level2/meta/table/Table.d.ts +1 -1
- package/packages/level2/meta/table/Table.funcs.js +1 -1
- package/packages/level2/meta/table/Table.js +3 -2
- package/packages/level2/meta/table/body/TableBody.funcs.d.ts +1 -1
- package/packages/level2/meta/table/body/TableBody.funcs.js +2 -1
- package/packages/level2/meta/table/body/TableBody.js +2 -2
- package/packages/level2/meta/table/body-cell/ActionBodyCell.funcs.js +1 -1
- package/packages/level2/meta/table/body-cell/BlobBodyCell.funcs.js +1 -1
- package/packages/level2/meta/table/body-cell/BodyCell.funcs.js +2 -1
- package/packages/level2/meta/table/body-cell/BodyCellArrayTooltip.funcs.js +1 -1
- package/packages/level2/meta/table/body-cell/MultiselectCellTemplate.funcs.js +1 -1
- package/packages/level2/meta/table/body-cell/ViewCell.funcs.js +1 -1
- package/packages/level2/meta/table/body-row/TableBodyRow.funcs.js +1 -1
- package/packages/level2/meta/table/csv-converter.js +3 -2
- package/packages/level2/meta/table/header/TableHeader.funcs.js +1 -1
- package/packages/level2/meta/table/header/TableHeader.js +1 -1
- package/packages/level2/meta/table/header-cell/Resizable.d.ts +1 -2
- package/packages/level2/meta/table/header-cell/TableHeaderActionCell.funcs.js +1 -1
- package/packages/level2/meta/table/header-cell/TableHeaderCell.funcs.js +2 -1
- package/packages/level2/meta/table/header-cell/TableHeaderCell.js +1 -1
- package/packages/level2/meta/table/pager/Pager.funcs.js +1 -1
- package/packages/level2/meta/table/services/fd-private-paging.js +1 -1
- package/packages/level2/meta/table/services/fd-table-private-column-calculation.js +1 -1
- package/packages/level2/meta/table/services/fd-table-private-columns.js +1 -1
- package/packages/level2/meta/table/services/fd-table-private-create-columns.d.ts +1 -1
- package/packages/level2/meta/table/services/fd-table-private-create-columns.js +1 -1
- package/packages/level2/meta/table/services/fd-table-private-properties.js +1 -1
- package/packages/level2/meta/table/services/fd-table-private-resize-columns.js +3 -1
- package/packages/level2/meta/table/services/fd-table-private-rows.js +1 -1
- package/packages/level2/meta/table/services/fd-table-private-sorting.js +1 -1
- package/packages/level2/meta/table/services/table-private-cell.js +1 -1
- package/packages/level2/meta/table/table-constants.js +1 -1
- package/packages/level2/meta/table/table-custom-action/TableCustomAction.funcs.js +1 -1
- package/packages/level2/meta/table/table-custom-attributes.d.ts +2 -2
- package/packages/level2/meta/table/table-custom-attributes.js +1 -1
- package/packages/level2/meta/ui/ui-relation.js +1 -1
- package/packages/level2/meta/ui-meta-providers.js +1 -1
- package/packages/level2/meta/view/View.js +46 -55
- package/packages/level2/meta/view/ViewSheet.d.ts +7 -9
- package/packages/level2/meta/view/ViewSheet.funcs.d.ts +1 -1
- package/packages/level2/meta/view/ViewSheet.funcs.js +1 -1
- package/packages/level2/meta/view/ViewSheet.js +4 -4
- package/packages/level2/meta/view/view-constants.d.ts +4 -4
- package/packages/level2/meta/view/view-constants.js +4 -2
- package/packages/level2/npm-commands/gen-dynamic-handlers-map/generate-dynamic-handlers-map.js +5 -4
- package/packages/level2/npm-commands/gen-meta/generate-meta.js +2 -2
- package/packages/level2/npm-commands/gen-meta/generate-tsconfig.js +3 -2
- package/packages/level2/npm-commands/gen-schema/gen-schema.js +2 -1
- package/packages/level2/npm-commands/gen-schema/transpile-schema.js +2 -1
- package/packages/level2/npm-commands/migrate-db/migrate-db.js +2 -1
- package/packages/level2/npm-commands/npm-comands-paths.d.ts +2 -2
- package/packages/level2/npm-commands/npm-comands-paths.js +2 -3
- package/packages/level2/npm-commands/run-command/index.js +3 -3
- package/packages/level2/npm-commands/seed-db/seed-db.js +2 -1
- package/packages/level2/npm-commands/server/db/fd-db-initializer.js +1 -4
- package/packages/level2/other/scrapping/scrape-constants.d.ts +0 -2
- package/packages/level2/other/scrapping/scrape-constants.js +4 -2
- package/packages/level2/other/scrapping/scrape.command.js +1 -1
- package/packages/level2/other/scrapping/scrapper-config.js +1 -1
- package/packages/level2/other/scrapping/scrappers.js +3 -3
- package/packages/level2/server/addresses/address-db.js +1 -1
- package/packages/level2/server/addresses/address-master-data.js +2 -2
- package/packages/level2/server/addresses/country-db.js +1 -1
- package/packages/level2/server/addresses/country-master-data.js +2 -1
- package/packages/level2/server/ai/ai-generated-text.d.ts +1 -3
- package/packages/level2/server/ai/ai-generated-text.js +1 -2
- package/packages/level2/server/auth/dev-demo-permissions.js +1 -1
- package/packages/level2/server/auth/oauth-service-db.js +2 -2
- package/packages/level2/server/auth/permission-master-data.js +1 -2
- package/packages/level2/server/auth/permission-role-mapping.js +1 -1
- package/packages/level2/server/auth/role-db.js +4 -3
- package/packages/level2/server/auth/role-master-data.js +1 -1
- package/packages/level2/server/auth/role-to-permission-master-data.js +1 -1
- package/packages/level2/server/auth/role-to-permission-package.handlers.js +1 -1
- package/packages/level2/server/auth/role-to-permission.handlers.js +1 -1
- package/packages/level2/server/auth/role.handlers.js +1 -1
- package/packages/level2/server/auth/sign-in-api.d.ts +1 -3
- package/packages/level2/server/auth/sign-in-api.js +2 -2
- package/packages/level2/server/auth/sign-out-api.d.ts +1 -3
- package/packages/level2/server/auth/sign-out-api.js +2 -2
- package/packages/level2/server/auth/sign-up-api.d.ts +1 -3
- package/packages/level2/server/auth/sign-up-api.js +1 -2
- package/packages/level2/server/blob/blob-db.js +2 -2
- package/packages/level2/server/business-profile/business-profile-api.d.ts +1 -3
- package/packages/level2/server/business-profile/business-profile-api.js +2 -2
- package/packages/level2/server/comments/comment-db.js +1 -1
- package/packages/level2/server/comments/comment-master-data.js +1 -1
- package/packages/level2/server/constants/dev-test.d.ts +4 -0
- package/packages/level2/server/constants/dev-test.js +4 -0
- package/packages/level2/server/constants/path.d.ts +1 -1
- package/packages/level2/server/constants/path.js +3 -1
- package/packages/level2/server/constants/url-placeholders.d.ts +3 -0
- package/packages/level2/server/constants/url-placeholders.js +4 -0
- package/packages/level2/server/constants/workspace-settings.js +2 -1
- package/packages/level2/server/customers/customer-db.js +1 -1
- package/packages/level2/server/customers/customer-master-data.js +1 -1
- package/packages/level2/server/dashboards/dashboard-db.js +1 -1
- package/packages/level2/server/dashboards/dashboard-master-data.js +1 -1
- package/packages/level2/server/dashboards/dashboard-report-data-master-data.d.ts +64 -9
- package/packages/level2/server/dashboards/dashboard-report-data-master-data.js +3 -1
- package/packages/level2/server/dashboards/dashboard-report-db.js +1 -1
- package/packages/level2/server/dashboards/dashboard-report-master-data.js +1 -1
- package/packages/level2/server/db/db.d.ts +1 -0
- package/packages/level2/server/db/db.js +8 -4
- package/packages/level2/server/demo/companies/company-db.js +1 -1
- package/packages/level2/server/demo/companies/company-master-data.js +4 -4
- package/packages/level2/server/demo/contacts/contact-db.js +1 -1
- package/packages/level2/server/demo/contacts/contact-master-data.js +3 -5
- package/packages/level2/server/demo/deals/deal-db.js +1 -1
- package/packages/level2/server/demo/deals/deal-master-data.js +1 -1
- package/packages/level2/server/demo/demo-seed-constants.d.ts +38 -0
- package/packages/level2/server/demo/demo-seed-constants.js +8 -0
- package/packages/level2/server/demo/reset-data-api.d.ts +1 -3
- package/packages/level2/server/demo/reset-data-api.js +2 -3
- package/packages/level2/server/demo/tickets/ticket-db.js +1 -1
- package/packages/level2/server/demo/tickets/ticket-master-data.js +1 -1
- package/packages/level2/server/dev/ai-assistant/ai-assistant-db.js +1 -1
- package/packages/level2/server/dev/ai-assistant/ai-assistant-master-data.js +1 -1
- package/packages/level2/server/dev/ai-assistant/ai-assistant-mother.d.ts +2 -2
- package/packages/level2/server/dev/ai-assistant/ai-assistant-mother.js +2 -1
- package/packages/level2/server/dev/dev-greeting/dev-greeting-master-data.js +1 -1
- package/packages/level2/server/dev/dev-greeting/dev-greeting-mother.js +1 -1
- package/packages/level2/server/dev/friends/friend-db.js +1 -1
- package/packages/level2/server/dev/friends/friend-master-data.js +1 -1
- package/packages/level2/server/dev/friends/friend-mother.js +1 -1
- package/packages/level2/server/dev/friends/friend-utils.js +4 -3
- package/packages/level2/server/dev/jobs/job-db.js +1 -1
- package/packages/level2/server/dev/jobs/job-master-data.js +1 -1
- package/packages/level2/server/dev/jobs/job-mother.js +3 -1
- package/packages/level2/server/dev/paper-planes/paper-plane-db.js +1 -1
- package/packages/level2/server/dev/paper-planes/paper-plane-master-data.js +1 -1
- package/packages/level2/server/dev/paper-planes/paper-plane-mother.js +1 -1
- package/packages/level2/server/dev/paper-planes/paper-plane.handlers.js +1 -1
- package/packages/level2/server/dev/persons/person-constants.js +3 -1
- package/packages/level2/server/dev/persons/person-db.js +1 -1
- package/packages/level2/server/dev/persons/person-master-data.js +1 -1
- package/packages/level2/server/dev/persons/person-mother.d.ts +21 -14
- package/packages/level2/server/dev/persons/person-mother.js +3 -2
- package/packages/level2/server/dev/persons/person-to-job-db.js +1 -1
- package/packages/level2/server/dev/persons/person-to-job-master-data.js +1 -1
- package/packages/level2/server/dev/persons/person-to-job-mother.js +1 -1
- package/packages/level2/server/dev/persons/person-to-person-db.js +1 -1
- package/packages/level2/server/dev/persons/person-to-person-master-data.js +1 -1
- package/packages/level2/server/dev/persons/person-to-person-mother.d.ts +2 -2
- package/packages/level2/server/dev/persons/person-to-person-mother.js +2 -1
- package/packages/level2/server/dev/persons/person.handlers.js +1 -1
- package/packages/level2/server/dev/phone-brands/phone-brand-db.js +1 -1
- package/packages/level2/server/dev/phone-brands/phone-brand-master-data.js +1 -1
- package/packages/level2/server/dev/phone-brands/phone-brand-mother.js +2 -1
- package/packages/level2/server/dev/pings/ping-db.js +1 -1
- package/packages/level2/server/dev/pings/ping-master-data.js +1 -1
- package/packages/level2/server/dev/pings/ping-mother.js +1 -1
- package/packages/level2/server/example/example-api.d.ts +5 -12
- package/packages/level2/server/example/example-api.js +1 -2
- package/packages/level2/server/export/csv-data-formatter.js +1 -1
- package/packages/level2/server/export/export-api.d.ts +1 -3
- package/packages/level2/server/export/export-api.js +1 -2
- package/packages/level2/server/fd/fd-toolbox-asp-net/models/roles/role-to-permission-db.js +4 -3
- package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission-db.js +4 -3
- package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission-package-db.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission-package-to-db.js +4 -3
- package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission-package-to-permission.handlers.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission-package.handlers.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission.handlers.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/constants/db-initialization-messages.d.ts +0 -1
- package/packages/level2/server/fd/fd-toolbox-web/constants/db-initialization-messages.js +3 -1
- package/packages/level2/server/fd/fd-toolbox-web/http/base-http-client.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/localization/language/language-db.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/localization/language/language-master-data.js +2 -1
- package/packages/level2/server/fd/fd-toolbox-web/logging/log-api.d.ts +3 -9
- package/packages/level2/server/fd/fd-toolbox-web/logging/log-api.js +1 -2
- package/packages/level2/server/fd/fd-toolbox-web/mailing/fd-emails.js +2 -1
- package/packages/level2/server/fd/fd-toolbox-web/models/reset-password-request.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/notifications/notification-db.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/permissions/fd-permission-master-data.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/permissions/permission-api.d.ts +1 -3
- package/packages/level2/server/fd/fd-toolbox-web/permissions/permission-api.js +1 -2
- package/packages/level2/server/fd/fd-toolbox-web/resources/resource-property-db.js +4 -3
- package/packages/level2/server/fd/fd-toolbox-web/seeding/notification-master-data.js +2 -2
- package/packages/level2/server/fd/fd-toolbox-web/seeding/resource-master-data.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/seeding/resource-property-master-data.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/seeding/workspace-master-data.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/services/notifications.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/services/socket/web-socket-server.js +1 -1
- package/packages/level2/server/fd/fd-toolbox-web/services/socket/web-sockets.js +4 -1
- package/packages/level2/server/features/feature-db.js +4 -3
- package/packages/level2/server/features/feature-master-data.js +1 -1
- package/packages/level2/server/features/feature-mother.js +1 -1
- package/packages/level2/server/features/features.js +1 -1
- package/packages/level2/server/features/payment-plan-feature-data.js +1 -1
- package/packages/level2/server/features/payment-plan-feature-db.js +1 -1
- package/packages/level2/server/features/status-board-master-data.js +2 -1
- package/packages/level2/server/features/user-feature.handlers.js +1 -1
- package/packages/level2/server/feeds/feed-entry-data.js +2 -1
- package/packages/level2/server/html/email.js +4 -2
- package/packages/level2/server/html-templates/email-notification.html +96 -0
- package/packages/level2/server/html-templates/send-email-form.html +123 -0
- package/packages/level2/server/html-templates/workspace-invite-footer.html +3 -0
- package/packages/level2/server/html-templates/workspace-invite-template.html +123 -0
- package/packages/level2/server/index.d.ts +1 -3
- package/packages/level2/server/index.js +2 -2
- package/packages/level2/server/infra/background-jobs/background-jobs.js +4 -3
- package/packages/level2/server/infra/background-jobs/init-jobs.js +2 -1
- package/packages/level2/server/infra/workspaces/workspace-setting-db.js +1 -1
- package/packages/level2/server/integration/data/deleted/integration-deleted-api.d.ts +1 -3
- package/packages/level2/server/integration/data/deleted/integration-deleted-api.js +1 -2
- package/packages/level2/server/integration/data/dynamicfields/integration-dynamicfields-api.d.ts +1 -3
- package/packages/level2/server/integration/data/dynamicfields/integration-dynamicfields-api.js +1 -2
- package/packages/level2/server/integration/integration-api.d.ts +3 -9
- package/packages/level2/server/integration/integration-api.js +1 -2
- package/packages/level2/server/integration-platforms/integration-resource.js +1 -1
- package/packages/level2/server/integration-platforms/subscription-odata.js +3 -2
- package/packages/level2/server/integrations/aio/blobs.js +5 -4
- package/packages/level2/server/integrations/blob/blob-storage.js +1 -1
- package/packages/level2/server/integrations/google-place/google-place-helpers.js +1 -1
- package/packages/level2/server/integrations/google-place/google-place.handlers.js +1 -1
- package/packages/level2/server/integrations/google-place/google-place.js +4 -3
- package/packages/level2/server/integrations/remote-blob/remote-blob-storage.js +1 -1
- package/packages/level2/server/integrations/screenshot/get-website-screenshots.js +1 -1
- package/packages/level2/server/integrations/screenshot/screenshot-constants.d.ts +5 -0
- package/packages/level2/server/integrations/screenshot/screenshot-constants.js +4 -0
- package/packages/level2/server/integrations/screenshot/screenshot-controller.d.ts +1 -3
- package/packages/level2/server/integrations/screenshot/screenshot-controller.js +2 -3
- package/packages/level2/server/integrations/screenshot/screenshotone/screenshotone-client.js +2 -2
- package/packages/level2/server/integrations/website-scan/scan-social-media-and-email-constants.d.ts +1 -1
- package/packages/level2/server/integrations/website-scan/scan-social-media-and-email-constants.js +4 -1
- package/packages/level2/server/integrations/website-scan/scan-social-media-and-email.js +2 -2
- package/packages/level2/server/integrations/website-scan/website-scan-initializer.js +1 -1
- package/packages/level2/server/items/item-db.js +5 -4
- package/packages/level2/server/leads/lead-category-db.js +1 -1
- package/packages/level2/server/leads/lead-category-master-data.js +1 -1
- package/packages/level2/server/leads/lead-db.js +1 -1
- package/packages/level2/server/leads/lead-email-db.js +1 -1
- package/packages/level2/server/leads/lead-email-master-data.js +1 -1
- package/packages/level2/server/leads/lead-group-db.js +1 -1
- package/packages/level2/server/leads/lead-group-master-data.js +2 -1
- package/packages/level2/server/leads/lead-master-data.js +1 -1
- package/packages/level2/server/leads/lead-to-lead-category-db.js +1 -1
- package/packages/level2/server/leads/lead-to-lead-category-master-data.js +1 -1
- package/packages/level2/server/leads/lead-to-lead-group-db.js +1 -1
- package/packages/level2/server/leads/lead-to-lead-group-master-data.js +1 -1
- package/packages/level2/server/leads/lead-to-lead-group.handlers.js +1 -1
- package/packages/level2/server/leads/lead.handlers.js +1 -1
- package/packages/level2/server/leads/services/ai-scan-result-delete.js +1 -1
- package/packages/level2/server/markdown/markdown-api.d.ts +1 -3
- package/packages/level2/server/markdown/markdown-api.js +1 -2
- package/packages/level2/server/markdown/markdown.js +1 -1
- package/packages/level2/server/media/media-api.d.ts +3 -9
- package/packages/level2/server/media/media-api.js +5 -3
- package/packages/level2/server/notifications/notification.handlers.js +1 -1
- package/packages/level2/server/orders/order-db.js +1 -1
- package/packages/level2/server/orders/order-master-data.js +1 -1
- package/packages/level2/server/orders/order-utils.js +1 -1
- package/packages/level2/server/orders/order.handlers.js +1 -1
- package/packages/level2/server/otheruser/id/otheruser-id-api.d.ts +5 -12
- package/packages/level2/server/otheruser/id/otheruser-id-api.js +1 -2
- package/packages/level2/server/otheruser/otheruser-api.d.ts +3 -9
- package/packages/level2/server/otheruser/otheruser-api.js +1 -2
- package/packages/level2/server/password/editpassword/editpassword-api.d.ts +1 -3
- package/packages/level2/server/password/editpassword/editpassword-api.js +2 -2
- package/packages/level2/server/password/forgotpassword/forgotpassword-api.d.ts +1 -3
- package/packages/level2/server/password/forgotpassword/forgotpassword-api.js +3 -3
- package/packages/level2/server/password/resetpassword/resetpassword-api.d.ts +1 -3
- package/packages/level2/server/password/resetpassword/resetpassword-api.js +1 -2
- package/packages/level2/server/payment/method/payment-method-api.d.ts +2 -6
- package/packages/level2/server/payment/method/payment-method-api.js +1 -2
- package/packages/level2/server/payment/verify-fail/payment-verify-fail-api.d.ts +1 -3
- package/packages/level2/server/payment/verify-fail/payment-verify-fail-api.js +1 -2
- package/packages/level2/server/payment/verify-success/payment-verify-success.d.ts +1 -3
- package/packages/level2/server/payment/verify-success/payment-verify-success.js +1 -2
- package/packages/level2/server/payments/payment-plan.handlers.js +3 -3
- package/packages/level2/server/payments/payments/payment-plan-db.js +5 -4
- package/packages/level2/server/payments/payments/payment-plan-master-data.js +1 -1
- package/packages/level2/server/payments/payments/payment-plans.js +1 -1
- package/packages/level2/server/payments/payments/payments-api.d.ts +1 -3
- package/packages/level2/server/payments/payments/payments-api.js +1 -2
- package/packages/level2/server/payments/payments/payments.js +2 -2
- package/packages/level2/server/payments/payments/pricing-seeding.js +1 -1
- package/packages/level2/server/payments/pricing.handlers.js +1 -1
- package/packages/level2/server/payments/stripe/stripe-sync.js +2 -2
- package/packages/level2/server/payments/stripe/stripes.js +3 -3
- package/packages/level2/server/payments/subscriptions/subscription-db.js +4 -3
- package/packages/level2/server/payments/subscriptions/subscriptions.js +1 -1
- package/packages/level2/server/payments/system-invoice/payment-system-invoice.handlers.js +1 -1
- package/packages/level2/server/product-setup/website-analysiz.d.ts +0 -2
- package/packages/level2/server/product-setup/website-analysiz.js +3 -3
- package/packages/level2/server/products/product-db.js +1 -1
- package/packages/level2/server/products/product-master-data.js +2 -1
- package/packages/level2/server/products/product-media/product-media-db.js +1 -1
- package/packages/level2/server/products/product-media/product-media-master-data.d.ts +5 -0
- package/packages/level2/server/products/product-media/product-media-master-data.js +2 -2
- package/packages/level2/server/products/product-parameters/product-parameter-mother.d.ts +1 -1
- package/packages/level2/server/products/product-parameters/product-parameter-mother.js +2 -1
- package/packages/level2/server/reports/report-chart-series-master-data.js +1 -1
- package/packages/level2/server/reports/report-chart-series-mother.d.ts +217 -49
- package/packages/level2/server/reports/report-chart-series-mother.js +2 -1
- package/packages/level2/server/reports/report-db.js +1 -1
- package/packages/level2/server/reports/report-master-data.js +1 -1
- package/packages/level2/server/reports/report-mother.d.ts +1 -1
- package/packages/level2/server/reports/report-mother.js +3 -1
- package/packages/level2/server/reports/report-string-constants.d.ts +19 -0
- package/packages/level2/server/reports/report-string-constants.js +8 -0
- package/packages/level2/server/reports/report-with-data.handlers.d.ts +1 -10
- package/packages/level2/server/reports/report-with-data.handlers.js +1 -1
- package/packages/level2/server/search/search-result-api.d.ts +1 -3
- package/packages/level2/server/search/search-result-api.js +1 -2
- package/packages/level2/server/search/search-result.js +1 -1
- package/packages/level2/server/search/search.handlers.js +1 -1
- package/packages/level2/server/search/searchable-resource.handlers.js +1 -1
- package/packages/level2/server/seeding/seed-master-data.js +1 -2
- package/packages/level2/server/shipment/shipment-api.js +1 -1
- package/packages/level2/server/shipment/shipment-constants.js +3 -1
- package/packages/level2/server/shipment/shipment-db.js +1 -1
- package/packages/level2/server/shipment/shipment-master-data.js +1 -1
- package/packages/level2/server/shipment/shipment.handlers.js +1 -1
- package/packages/level2/server/statusboard/statusboard-api.d.ts +3 -9
- package/packages/level2/server/statusboard/statusboard-api.js +1 -2
- package/packages/level2/server/store/store-constants.d.ts +1 -1
- package/packages/level2/server/store/store-constants.js +3 -1
- package/packages/level2/server/store/store-db.js +1 -1
- package/packages/level2/server/store/store-master-data.js +3 -3
- package/packages/level2/server/subscription/cancel/subscription-cancel-api.d.ts +1 -3
- package/packages/level2/server/subscription/cancel/subscription-cancel-api.js +1 -2
- package/packages/level2/server/subscription/create/subscription-create-api.d.ts +1 -3
- package/packages/level2/server/subscription/create/subscription-create-api.js +1 -2
- package/packages/level2/server/subscription/update/subscription-update-api.d.ts +1 -3
- package/packages/level2/server/subscription/update/subscription-update-api.js +1 -2
- package/packages/level2/server/system-settings/system-master-data.js +1 -1
- package/packages/level2/server/system-settings/system-setting-db.js +1 -1
- package/packages/level2/server/system-settings/system-settings.js +3 -1
- package/packages/level2/server/test/data/test-constants.js +3 -1
- package/packages/level2/server/test/data/test-data-api.d.ts +1 -3
- package/packages/level2/server/test/data/test-data-api.js +1 -2
- package/packages/level2/server/test/data/test-data.js +2 -2
- package/packages/level2/server/upload/upload-api.d.ts +2 -6
- package/packages/level2/server/upload/upload-api.js +1 -2
- package/packages/level2/server/usage-limit/usage-limit.js +2 -2
- package/packages/level2/server/user-settings/user-setting.handlers.js +1 -1
- package/packages/level2/server/userfeature/isenabled/userfeature-isenabled-api.d.ts +1 -3
- package/packages/level2/server/userfeature/isenabled/userfeature-isenabled-api.js +1 -2
- package/packages/level2/server/users/admin-edit-admin.js +1 -1
- package/packages/level2/server/users/auth.js +2 -1
- package/packages/level2/server/users/edit-other-users.js +1 -1
- package/packages/level2/server/users/tokens.js +4 -2
- package/packages/level2/server/users/user-creation-service.js +2 -1
- package/packages/level2/server/users/user-db.js +6 -4
- package/packages/level2/server/users/user-deletions.js +1 -1
- package/packages/level2/server/users/user-feature-db.js +4 -3
- package/packages/level2/server/users/user-feature-predicates.js +4 -2
- package/packages/level2/server/users/user-manager.d.ts +2 -7
- package/packages/level2/server/users/user-manager.js +9 -5
- package/packages/level2/server/users/user-master-data.js +3 -1
- package/packages/level2/server/users/user-mother.js +3 -2
- package/packages/level2/server/users/user-role.handlers.js +1 -1
- package/packages/level2/server/users/user-role.js +1 -1
- package/packages/level2/server/users/user-service.js +1 -1
- package/packages/level2/server/users/user-settings/user-setting-db.js +5 -4
- package/packages/level2/server/users/user-token-constants.d.ts +3 -0
- package/packages/level2/server/users/user-token-constants.js +4 -0
- package/packages/level2/server/users/user.handlers.js +1 -1
- package/packages/level2/server/utils/base-resource-properties.js +1 -1
- package/packages/level2/server/utils/check-resource-access-permission.js +1 -1
- package/packages/level2/server/utils/get-user-and-workspace-ids.js +1 -1
- package/packages/level2/server/utils/map-subscription-status-to-db-format.js +2 -1
- package/packages/level2/server/web/http-wrapper.d.ts +1 -2
- package/packages/level2/server/web/http-wrapper.js +1 -2
- package/packages/level2/server/web/initialize.js +2 -1
- package/packages/level2/server/web/responses/create-remote-blob-response.js +1 -1
- package/packages/level2/server/workspace/change-current-workspace.d.ts +1 -1
- package/packages/level2/server/workspace/change-current-workspace.js +1 -1
- package/packages/level2/server/workspace/visible-workspace-api.d.ts +2 -6
- package/packages/level2/server/workspace/visible-workspace-api.js +1 -2
- package/packages/level2/server/workspace/workspace-api.d.ts +2 -6
- package/packages/level2/server/workspace/workspace-api.js +2 -2
- package/packages/level2/server/workspace/workspace-invite/user-workspace-invite.handlers.js +4 -1
- package/packages/level2/server/workspace/workspace-invite/workspace-user-invites.js +1 -1
- package/packages/test-infra/asserters/edit-asserts.d.ts +3 -1
- package/packages/test-infra/asserters/edit-asserts.js +6 -4
- package/packages/test-infra/asserters/forgot-password-asserts.js +1 -1
- package/packages/test-infra/asserters/navigation-asserts.js +1 -1
- package/packages/test-infra/asserters/notification-asserts.js +1 -1
- package/packages/test-infra/asserters/search-asserts.js +1 -1
- package/packages/test-infra/asserters/table-asserts.js +5 -3
- package/packages/test-infra/asserters/ui-asserts.d.ts +5 -0
- package/packages/test-infra/asserters/ui-asserts.js +6 -4
- package/packages/test-infra/constants/test-data/input-fields-values.js +2 -2
- package/packages/test-infra/constants/test-data/table-headers.js +4 -1
- package/packages/test-infra/constants/test-data/test-names.js +3 -1
- package/packages/test-infra/constants/ui-tester/checkout-form-test-data.js +3 -2
- package/packages/test-infra/constants/ui-tester/html-contants.d.ts +7 -4
- package/packages/test-infra/constants/ui-tester/html-contants.js +2 -2
- package/packages/test-infra/fixtures/error-tracking-fixture.js +1 -1
- package/packages/test-infra/page-objects/account-setup-po.js +1 -1
- package/packages/test-infra/page-objects/browser-po.js +1 -1
- package/packages/test-infra/page-objects/checkout-form-po.js +1 -1
- package/packages/test-infra/page-objects/edit-po.js +1 -1
- package/packages/test-infra/page-objects/filter-po.js +2 -1
- package/packages/test-infra/page-objects/forgot-password-po.js +2 -2
- package/packages/test-infra/page-objects/list-po.js +1 -1
- package/packages/test-infra/page-objects/login-po.js +1 -1
- package/packages/test-infra/page-objects/multi-browser-po.js +1 -1
- package/packages/test-infra/page-objects/notification-po.js +1 -1
- package/packages/test-infra/page-objects/payment-plan-po.js +1 -1
- package/packages/test-infra/page-objects/reset-password-po.js +1 -1
- package/packages/test-infra/page-objects/search-po.js +1 -1
- package/packages/test-infra/page-objects/select-workspace-po.js +4 -2
- package/packages/test-infra/page-objects/sidebar-po.js +2 -2
- package/packages/test-infra/page-objects/table-asserts.d.ts +1 -1
- package/packages/test-infra/page-objects/table-asserts.js +1 -1
- package/packages/test-infra/page-objects/toolbar-po.js +1 -1
- package/packages/test-infra/page-objects/user-menu-po.js +1 -1
- package/packages/test-infra/page-objects/user-setting-po.js +2 -1
- package/packages/test-infra/page-objects/view-po.js +1 -1
- package/packages/test-infra/playwright-setup/global-setup.d.ts +1 -2
- package/packages/test-infra/playwright-setup/global-setup.js +1 -3
- package/packages/test-infra/playwright-setup/global-teardown.js +1 -1
- package/packages/test-infra/test-data/crud-tests/crud-test-data-factory.js +1 -1
- package/packages/test-infra/test-data/crud-tests/crud-test-data.js +1 -1
- package/packages/test-infra/test-data/crud-tests/relation-sync-info-provider.js +2 -1
- package/packages/test-infra/test-data/dev/friends/friends-mother.js +1 -1
- package/packages/test-infra/test-data/dev/persons/person-mother.js +2 -1
- package/packages/test-infra/test-data/dev/persons/phone-brand-mother.js +1 -1
- package/packages/test-infra/test-data/integration-tests/base-http-client.js +1 -1
- package/packages/test-infra/test-data/integration-tests/http-client.js +2 -1
- package/packages/test-infra/test-data/integration-tests/result-comparer.js +1 -1
- package/packages/test-infra/test-data/integration-tests/workspace.js +1 -4
- package/packages/test-infra/test-data/meta/person-property-metas.js +1 -1
- package/packages/test-infra/test-data/meta/resource-meta-mother.js +2 -2
- package/packages/test-infra/test-data/meta/ui-meta-mother.js +1 -1
- package/packages/test-infra/test-data/meta/ui-property-meta-mother.js +1 -1
- package/packages/test-infra/test-data/seed-test-data.js +1 -1
- package/packages/test-infra/ui-tester/global-ui-test.js +1 -1
- package/packages/test-infra/ui-tester/ui-tester.js +4 -4
- package/packages/tools/string-duplication/analyze-code-base.js +4 -0
- package/packages/tools/string-duplication/directives.d.ts +6 -0
- package/packages/tools/string-duplication/directives.js +4 -0
- package/packages/tools/string-duplication/handlers.js +2 -2
- package/packages/tools/string-duplication/normalizer.js +1 -1
- package/packages/tools/string-duplication/reporter.d.ts +1 -1
- package/packages/tools/string-duplication/reporter.js +2 -1
- package/packages/tools/string-duplication/resolver.js +1 -1
- package/packages/tools/string-duplication/string-extractor.d.ts +1 -0
- package/packages/tools/string-duplication/string-extractor.js +3 -2
- package/server/index.d.ts +5 -4
- package/server/index.js +3 -3
- package/src/app/http-wrappers.d.ts +5 -2
- package/src/app/http-wrappers.js +2 -2
- package/src/app/init-saas-kit.d.ts +1 -0
- package/src/app/init-saas-kit.js +8 -0
- package/test-infra/index.d.ts +4 -11
- package/test-infra/index.js +3 -8
- package/undocumented/index.d.ts +285 -312
- package/undocumented/index.js +228 -249
- package/packages/base-repo/constants.d.ts +0 -5
- package/packages/base-repo/constants.js +0 -4
- package/packages/base-repo/tools/git/pre-commit-script.d.ts +0 -5
- package/packages/base-repo/tools/git/pre-commit-script.js +0 -12
- package/packages/fd-toolbox/infra/env-store.d.ts +0 -3
- package/packages/fd-toolbox/infra/env-store.js +0 -7
- package/packages/fd-toolbox/schema-constants/schema-names.d.ts +0 -21
- package/packages/fd-toolbox/schema-constants/schema-names.js +0 -7
- package/packages/fd-toolbox/server/constants/std-events.d.ts +0 -3
- package/packages/fd-toolbox/server/constants/std-events.js +0 -4
- package/packages/level2/client/pages/leads-viw-page/LeadsViewPage.d.ts +0 -2
- package/packages/level2/client/pages/leads-viw-page/LeadsViewPage.js +0 -18
- package/packages/level2/client/website-scan/WebsiteScanResult.d.ts +0 -6
- package/packages/level2/client/website-scan/WebsiteScanResult.funcs.d.ts +0 -4
- package/packages/level2/client/website-scan/WebsiteScanResult.funcs.js +0 -28
- package/packages/level2/client/website-scan/WebsiteScanResult.js +0 -62
- package/packages/level2/common/hd/hd-constants/hd-enums.d.ts +0 -5
- package/packages/level2/common/hd/hd-constants/hd-enums.js +0 -4
- package/packages/level2/common/hd/resources/hd-product.resource.d.ts +0 -7
- package/packages/level2/common/hd/resources/hd-product.resource.js +0 -7
- package/packages/level2/common/leads/lm/google-place.resource-ext.d.ts +0 -3
- package/packages/level2/common/leads/lm/google-place.resource-ext.js +0 -6
- package/packages/level2/common/lm/constants/lm-notifications.d.ts +0 -28
- package/packages/level2/common/lm/constants/lm-notifications.js +0 -4
- package/packages/level2/common/lm/models/save-to-group-request.d.ts +0 -5
- package/packages/level2/common/lm/models/save-to-group-request.js +0 -1
- package/packages/level2/common/lm/models/save-to-group-response.d.ts +0 -3
- package/packages/level2/common/lm/models/save-to-group-response.js +0 -1
- package/packages/level2/fd-app-toolbox/form-constants/forms.d.ts +0 -3
- package/packages/level2/fd-app-toolbox/form-constants/forms.js +0 -4
- package/packages/level2/fd-app-toolbox/infra/app-toolbox-env-setting-keys.d.ts +0 -3
- package/packages/level2/fd-app-toolbox/infra/app-toolbox-env-setting-keys.js +0 -4
- package/packages/level2/fd-app-toolbox/report/charts.d.ts +0 -8
- package/packages/level2/fd-app-toolbox/report/charts.js +0 -4
- package/packages/level2/fd-component-toolbox/back-button/BackButton.funcs.d.ts +0 -4
- package/packages/level2/fd-component-toolbox/back-button/BackButton.funcs.js +0 -4
- package/packages/level2/fd-component-toolbox/sheet/fd-sheet-constants.d.ts +0 -6
- package/packages/level2/fd-component-toolbox/sheet/fd-sheet-constants.js +0 -4
- package/packages/level2/fd-component-toolbox/tooltip/tooltip-constants.d.ts +0 -11
- package/packages/level2/fd-component-toolbox/tooltip/tooltip-constants.js +0 -4
- package/packages/level2/http-wrappers.d.ts +0 -4
- package/packages/level2/http-wrappers.js +0 -8
- package/packages/level2/meta/blob/blob-constants.d.ts +0 -6
- package/packages/level2/meta/blob/blob-constants.js +0 -4
- package/packages/level2/meta/server/constants/folder-names.d.ts +0 -7
- package/packages/level2/meta/server/constants/folder-names.js +0 -4
- package/packages/level2/meta/server/constants/meta-routes.d.ts +0 -3
- package/packages/level2/meta/server/constants/meta-routes.js +0 -4
- package/packages/level2/meta/server/constants/search-query-params.d.ts +0 -2
- package/packages/level2/meta/server/constants/search-query-params.js +0 -4
- package/packages/level2/meta/server/modules/get-generated-files.d.ts +0 -10
- package/packages/level2/meta/server/modules/get-generated-files.js +0 -19
- package/packages/level2/meta/server/modules/init-generated-files.d.ts +0 -1
- package/packages/level2/meta/server/modules/init-generated-files.js +0 -17
- package/packages/level2/meta/server/web/init-saas-kit.d.ts +0 -2
- package/packages/level2/meta/server/web/init-saas-kit.js +0 -7
- package/packages/level2/npm-commands/gen-exports/generate-exports-constants.d.ts +0 -34
- package/packages/level2/npm-commands/gen-exports/generate-exports-constants.js +0 -6
- package/packages/level2/server/auth/lm-permission-master-data.d.ts +0 -1
- package/packages/level2/server/auth/lm-permission-master-data.js +0 -7
- package/packages/level2/server/hd/plaid/plaid-constants.d.ts +0 -14
- package/packages/level2/server/hd/plaid/plaid-constants.js +0 -4
- package/packages/level2/server/hd/plaid/plaid.d.ts +0 -26
- package/packages/level2/server/hd/plaid/plaid.js +0 -12
- package/packages/level2/server/init-saas-kit.d.ts +0 -2
- package/packages/level2/server/init-saas-kit.js +0 -7
- package/packages/level2/server/lm/google-place/google-place-to-lead.d.ts +0 -2
- package/packages/level2/server/lm/google-place/google-place-to-lead.js +0 -15
- package/packages/level2/server/lm/google-place/save-to-group/save-to-group-api.d.ts +0 -6
- package/packages/level2/server/lm/google-place/save-to-group/save-to-group-api.js +0 -11
- package/packages/level2/server/lm/google-place-scan-website/google-place-scan-website-api.d.ts +0 -3
- package/packages/level2/server/lm/google-place-scan-website/google-place-scan-website-api.js +0 -13
- package/packages/level2/server/lm/lead-scan-website/lead-scan-website-api.d.ts +0 -3
- package/packages/level2/server/lm/lead-scan-website/lead-scan-website-api.js +0 -14
- package/packages/level2/server/media/media-master-data.d.ts +0 -4
- package/packages/level2/server/media/media-master-data.js +0 -14
- package/packages/test-infra/fixtures/custom-test-functions.d.ts +0 -40
- package/packages/test-infra/fixtures/custom-test-functions.js +0 -33
- package/packages/test-infra/fixtures/extend-test.d.ts +0 -9
- package/packages/test-infra/fixtures/extend-test.js +0 -10
- package/packages/test-infra/monorepo-global-setup.d.ts +0 -1
- package/packages/test-infra/monorepo-global-setup.js +0 -9
- package/packages/test-infra/monorepo-global-teardown.d.ts +0 -1
- package/packages/test-infra/monorepo-global-teardown.js +0 -7
- package/packages/tools/string-duplication/index.js +0 -11
- package/src/env.d.ts +0 -1
- package/src/env.js +0 -7
- package/src/hd/footer/HdFooter.d.ts +0 -2
- package/src/hd/footer/HdFooter.js +0 -52
- package/src/hd/footer/hd-footer-item/HdFooterItem.d.ts +0 -6
- package/src/hd/footer/hd-footer-item/HdFooterItem.js +0 -33
- package/src/hd/footer/hd-footer.d.ts +0 -10
- package/src/hd/footer/hd-footer.js +0 -4
- package/src/lm/ai-scan/AiScanAction.d.ts +0 -7
- package/src/lm/ai-scan/AiScanAction.funcs.d.ts +0 -5
- package/src/lm/ai-scan/AiScanAction.funcs.js +0 -11
- package/src/lm/ai-scan/AiScanAction.js +0 -37
- package/src/lm/ai-scan/cell-templates/AiScanWebsiteResultCellTemplate.d.ts +0 -3
- package/src/lm/ai-scan/cell-templates/AiScanWebsiteResultCellTemplate.js +0 -80
- package/src/lm/components/LmCardReport.d.ts +0 -7
- package/src/lm/components/LmCardReport.js +0 -36
- package/src/lm/configs/lm-list-configs.d.ts +0 -14
- package/src/lm/configs/lm-list-configs.js +0 -119
- package/src/lm/constants/lm-tooltip-labels.d.ts +0 -12
- package/src/lm/constants/lm-tooltip-labels.js +0 -4
- package/src/lm/google-place/action-dropdown/GooglePlaceActionDropdown.d.ts +0 -6
- package/src/lm/google-place/action-dropdown/GooglePlaceActionDropdown.funcs.d.ts +0 -11
- package/src/lm/google-place/action-dropdown/GooglePlaceActionDropdown.funcs.js +0 -4
- package/src/lm/google-place/action-dropdown/GooglePlaceActionDropdown.js +0 -104
- package/src/lm/google-place/action-dropdown/google-place-dropdown-actions.d.ts +0 -12
- package/src/lm/google-place/action-dropdown/google-place-dropdown-actions.js +0 -11
- package/src/lm/google-place/actions/GooglePlaceSaveToGroupAction.d.ts +0 -9
- package/src/lm/google-place/actions/GooglePlaceSaveToGroupAction.funcs.d.ts +0 -17
- package/src/lm/google-place/actions/GooglePlaceSaveToGroupAction.funcs.js +0 -12
- package/src/lm/google-place/actions/GooglePlaceSaveToGroupAction.js +0 -97
- package/src/lm/google-place/actions/google-place-delete-action.d.ts +0 -2
- package/src/lm/google-place/actions/google-place-delete-action.js +0 -4
- package/src/lm/google-place/actions/google-place-take-screenshot-action.d.ts +0 -2
- package/src/lm/google-place/actions/google-place-take-screenshot-action.js +0 -11
- package/src/lm/google-place/cell-templates/GooglePlaceBusinessInfoCellTemplate.d.ts +0 -5
- package/src/lm/google-place/cell-templates/GooglePlaceBusinessInfoCellTemplate.js +0 -80
- package/src/lm/google-place/cell-templates/GooglePlaceEmailsCellTemplate.d.ts +0 -5
- package/src/lm/google-place/cell-templates/GooglePlaceEmailsCellTemplate.funcs.d.ts +0 -3
- package/src/lm/google-place/cell-templates/GooglePlaceEmailsCellTemplate.funcs.js +0 -4
- package/src/lm/google-place/cell-templates/GooglePlaceEmailsCellTemplate.js +0 -95
- package/src/lm/google-place/cell-templates/GooglePlaceScanAction.d.ts +0 -7
- package/src/lm/google-place/cell-templates/GooglePlaceScanAction.funcs.d.ts +0 -6
- package/src/lm/google-place/cell-templates/GooglePlaceScanAction.funcs.js +0 -10
- package/src/lm/google-place/cell-templates/GooglePlaceScanAction.js +0 -52
- package/src/lm/lead/action-dropdown/LeadActionDropdown.d.ts +0 -6
- package/src/lm/lead/action-dropdown/LeadActionDropdown.funcs.d.ts +0 -5
- package/src/lm/lead/action-dropdown/LeadActionDropdown.funcs.js +0 -4
- package/src/lm/lead/action-dropdown/LeadActionDropdown.js +0 -97
- package/src/lm/lead/action-dropdown/lead-dropdown-actions.d.ts +0 -11
- package/src/lm/lead/action-dropdown/lead-dropdown-actions.js +0 -15
- package/src/lm/lead/actions/export-leads-action/export-leads-action.d.ts +0 -2
- package/src/lm/lead/actions/export-leads-action/export-leads-action.js +0 -7
- package/src/lm/lead/actions/move-to-group-action/LeadMoveToGroupAction.d.ts +0 -9
- package/src/lm/lead/actions/move-to-group-action/LeadMoveToGroupAction.funcs.d.ts +0 -6
- package/src/lm/lead/actions/move-to-group-action/LeadMoveToGroupAction.funcs.js +0 -9
- package/src/lm/lead/actions/move-to-group-action/LeadMoveToGroupAction.js +0 -90
- package/src/lm/lead/actions/save-to-group-action/lead-save-to-group-action.d.ts +0 -4
- package/src/lm/lead/actions/save-to-group-action/lead-save-to-group-action.js +0 -7
- package/src/lm/lead/actions/take-screenshot-action/lead-take-screenshot-action.d.ts +0 -15
- package/src/lm/lead/actions/take-screenshot-action/lead-take-screenshot-action.js +0 -12
- package/src/lm/lead/cell-templates/LeadBusinessInfoCellTemplate.d.ts +0 -5
- package/src/lm/lead/cell-templates/LeadBusinessInfoCellTemplate.js +0 -116
- package/src/lm/lead/cell-templates/LeadScanAction.d.ts +0 -7
- package/src/lm/lead/cell-templates/LeadScanAction.funcs.d.ts +0 -6
- package/src/lm/lead/cell-templates/LeadScanAction.funcs.js +0 -9
- package/src/lm/lead/cell-templates/LeadScanAction.js +0 -52
- package/src/lm/lead/lead-google-place/LeadGooglePlaceIndicator.d.ts +0 -7
- package/src/lm/lead/lead-google-place/LeadGooglePlaceIndicator.js +0 -29
- package/src/lm/lead/lead-google-place/LeadGooglePlaceIndicators.d.ts +0 -10
- package/src/lm/lead/lead-google-place/LeadGooglePlaceIndicators.js +0 -34
- package/src/lm/lead/lead-google-place/LeadGooglePlaceInfo.d.ts +0 -7
- package/src/lm/lead/lead-google-place/LeadGooglePlaceInfo.js +0 -36
- package/src/lm/lead/lead-google-place/lead-google-place-constants.d.ts +0 -13
- package/src/lm/lead/lead-google-place/lead-google-place-constants.js +0 -4
- package/src/lm/lead/view/LeadsView.d.ts +0 -1
- package/src/lm/lead/view/LeadsView.js +0 -24
- package/src/lm/lead-group/table-custom-action/lead-group-table-custom-action.d.ts +0 -3
- package/src/lm/lead-group/table-custom-action/lead-group-table-custom-action.js +0 -12
- package/src/lm/pages/HomePage.d.ts +0 -13
- package/src/lm/pages/HomePage.funcs.d.ts +0 -2
- package/src/lm/pages/HomePage.funcs.js +0 -13
- package/src/lm/pages/HomePage.js +0 -108
- /package/packages/{test-infra/constants/ui-tester → base-repo/constants}/ui-constants.d.ts +0 -0
- /package/packages/{test-infra/constants/ui-tester → base-repo/constants}/ui-constants.js +0 -0
- /package/packages/level2/{client → common}/website-scan/social-media-links.d.ts +0 -0
- /package/packages/level2/{client → common}/website-scan/social-media-links.js +0 -0
- /package/packages/tools/string-duplication/{index.d.ts → analyze-code-base.d.ts} +0 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
|
+
import { isTestFile, isGetIdFunction, isCallExpression } from '@flint/infra/analysis';
|
|
4
|
+
|
|
5
|
+
const ruleName='must-not-use-multiple-get-id-functions-inline-in-test';const ruleContent='\x0a###\x20**Must**\x20not\x20use\x20multiple\x20get\x20ID\x20functions\x20inline\x20in\x20test.\x0a\x0a####\x20Wrong\x0a\x0agetFooId(getBarId(baz));\x0a\x0a####\x20Correct\x0a\x0aconst\x20barId\x20=\x20getBarId(baz);\x0agetFooId(baz);\x0a\x0a####\x20Why\x0a\x0aExtracting\x20nested\x20getter\x20functions\x20into\x20separate\x20variables\x20improves\x20code\x20readability,\x20simplifies\x20debugging,\x20and\x20makes\x20the\x20test\x20flow\x20easier\x20to\x20understand.';var mustNotUseMultipleGetIdFunctionsInlineInTest = createEslintRule(ruleName,ruleContent,_0x16d4b3=>{return {'CallExpression'(_0x2393ec){if(!isTestFile(_0x16d4b3['filename'])||!isGetIdFunction(_0x2393ec['callee']))return;for(const _0x22c3fb of _0x2393ec['arguments']){isCallExpression(_0x22c3fb)&&isGetIdFunction(_0x22c3fb['callee'])&&_0x16d4b3['report']({'node':_0x2393ec,'messageId':ruleName});}}};});
|
|
6
|
+
|
|
7
|
+
export { mustNotUseMultipleGetIdFunctionsInlineInTest as default, ruleName };
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
|
+
import { isEmptyString } from '@flint/infra/analysis';
|
|
4
|
+
|
|
5
|
+
var __defProp=Object['defineProperty'],__name=(_0x4054f9,_0x39ddbe)=>__defProp(_0x4054f9,'name',{'value':_0x39ddbe,'configurable':!![]});const ruleName='must-not-use-nullish-coalescing-empty-string';const ruleContent='\x0a###\x20**Must\x20not**\x20use\x20nullish\x20coalescing\x20with\x20an\x20empty\x20string\x20default.\x0a\x0a####\x20Wrong\x0a\x0aconst\x20actualFilename\x20=\x20filenameParts.pop()\x20??\x20\x22\x22;\x0a\x0a####\x20Correct\x0a\x0aconst\x20actualFilename\x20=\x20filenameParts.pop();\x0a\x0aif\x20(!actualFilename)\x20throw\x20createError(\x22Filename\x20is\x20missing\x22);\x0a\x0a####\x20Why\x0a\x0aEmpty\x20strings\x20hide\x20missing\x20values\x20and\x20make\x20absence\x20handling\x20harder\x20to\x20reason\x20about.';var mustNotUseNullishCoalescingEmptyString = createEslintRule(ruleName,ruleContent,__name(function create(_0x3df6c7){return {'LogicalExpression'(_0x544633){if(_0x544633['operator']!=='??')return;isEmptyString(_0x544633['right'])&&_0x3df6c7['report']({'node':_0x544633['right'],'messageId':ruleName});}};},'create'));
|
|
6
|
+
|
|
7
|
+
export { mustNotUseNullishCoalescingEmptyString as default, ruleName };
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
3
|
import { nodeTypes } from '@flint/infra/analysis';
|
|
4
4
|
|
|
5
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
5
|
+
var __defProp=Object['defineProperty'],__name=(_0x529c59,_0x84c8b6)=>__defProp(_0x529c59,'name',{'value':_0x84c8b6,'configurable':!![]});const ruleName='must-not-use-placeholders-in-eslint-rule-titles';const ruleContent='\x0a###\x20**Must\x20not**\x20use\x20placeholders\x20in\x20eslint\x20rule\x20titles\x0a\x0a####\x20Wrong\x0a\x0a###\x20**Must**\x20use\x20{{name}}\x20in\x20rule\x20title.\x0a\x0a####\x20Correct\x0a\x0a###\x20**Must**\x20use\x20static\x20text\x20in\x20rule\x20title.\x0a\x0a####\x20Why\x0a\x0aRule\x20titles\x20must\x20be\x20static.\x20Dynamic\x20placeholders\x20make\x20messages\x20unclear,\x20inconsistent,\x20and\x20harder\x20to\x20search\x20or\x20reference.\x0a',rule=createEslintRule(ruleName,ruleContent,__name(function create(_0x4077f1){return {'VariableDeclarator'(_0x5c6285){let _0x4870d5=![];if(_0x5c6285['id']['type']===nodeTypes['identifier']&&_0x5c6285['id']['name']==='ruleContent'&&_0x5c6285['init']&&_0x5c6285['init']['type']===nodeTypes['templateLiteral']){const _0x21db0b=_0x5c6285['init']['quasis']['map'](_0x40c374=>_0x40c374['value']['cooked']??'')['join'](''),_0x293f4f=_0x21db0b['split']('\x0a')['map'](_0xa7c8b9=>_0xa7c8b9['trim']())['find'](_0x371386=>_0x371386['startsWith']('###'));_0x293f4f&&_0x293f4f['includes']('{{')&&_0x293f4f['includes']('}}')&&(_0x4870d5=!![]);}_0x4870d5&&_0x4077f1['report']({'node':_0x5c6285['id'],'messageId':ruleName});}};},'create'));
|
|
6
6
|
|
|
7
7
|
export { rule as default, ruleName };
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
3
|
import { nodeTypes, isIdentifier } from '@flint/infra/analysis';
|
|
4
|
+
import { navigationMethodNames, eslintFixTypeNames } from '../../base-repo/constants/common-strings.js';
|
|
4
5
|
|
|
5
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x2c6fe1,_0x291083)=>__defProp(_0x2c6fe1,'name',{'value':_0x291083,'configurable':!![]});const ruleName='must-not-use-see-link-in-docs-if-type-available';const ruleContent='\x0a###\x20**Must\x20not**\x20use\x20see\x20link\x20in\x20docs\x20if\x20type\x20available.\x0a\x0a####\x20Wrong\x0a\x0aexport\x20interface\x20FooProps\x20{\x0a\x20\x20\x20\x20/**\x20Meta\x20data\x20that\x20is\x20used\x20in\x20Foo\x20component,\x20@see\x20{@link\x20FooMetaData}*/\x0a\x20\x20\x20\x20fooMetaData:\x20FooMetaData;\x0a}\x0a\x0a####\x20Correct\x0a\x0aexport\x20interface\x20FooProps\x20{\x0a\x20\x20\x20\x20/**\x20Meta\x20data\x20that\x20is\x20used\x20in\x20Foo\x20component\x20*/\x0a\x20\x20\x20\x20fooMetaData:\x20FooMetaData;\x0a}\x0a\x0a####\x20Why\x0a\x0aLinks\x20to\x20imported\x20interfaces\x20and\x20types\x20of\x20properties\x20are\x20added\x20automatically,\x20there\x27s\x20no\x20need\x20to\x20duplicate\x20link\x20in\x20docs\x20comments';var mustNotUseSeeLinkInDocsIfTypeAvailable = createEslintRule(ruleName,ruleContent,__name(function create(_0x3c9718){const _0x696630=_0x3c9718['sourceCode'],_0x324267=/@see\s+{@link\s+([^}\s]+)\s*}/;return {'TSPropertySignature'(_0x1fc5a8){const _0x2c8193=_0x1fc5a8['typeAnnotation']?.['typeAnnotation'],_0x1cf4da=_0x696630['getCommentsBefore'](_0x1fc5a8);if(!_0x2c8193||_0x1cf4da['length']===-0x141e+0xc*0x29c+0x599*-0x2||_0x2c8193['type']!==nodeTypes['TSTypeReference']||!isIdentifier(_0x2c8193['typeName']))return;const _0x1f2fd8=_0x2c8193['typeName']['name'];_0x1cf4da['filter'](_0x236c3d=>_0x236c3d['type']===nodeTypes['Block']&&_0x236c3d['value']['startsWith']('*'))['forEach'](_0x4f1499=>{const _0x1b4182=_0x324267['exec'](_0x4f1499['value']);_0x1b4182&&_0x1b4182[0x1430+-0x56*-0x6f+-0x1*0x3979]===_0x1f2fd8&&_0x3c9718['report']({'node':_0x4f1499,'messageId':ruleName,'fix'(_0x5677ac){const _0x441f31=getFixInstruction(_0x4f1499,_0x1b4182,_0x696630);let _0x48911f=[];return _0x441f31['type']===constants['fixTypes']['replace']&&(_0x48911f=[_0x5677ac['replaceText'](_0x4f1499,_0x441f31['text'])]),_0x441f31['type']===constants['fixTypes']['removeRange']&&(_0x48911f=[_0x5677ac['removeRange']([_0x441f31['range'][0x11cc+0x7*0xb+-0x71*0x29],_0x441f31['range'][-0x1b7*-0xd+0x10fe+-0x2748]])]),_0x48911f;}});});}};},'create'),{'fixable':eslintFixTypeNames['code']});const constants={'patterns':{'seeLink':/@see{@link[^}]+}/},'fixTypes':{'removeRange':'removeRange','replace':navigationMethodNames['replace']}};function createRemoveRangeFix(_0x5b7b48,_0x153490){const _0x311cb4=[_0x5b7b48,_0x153490];return {'type':constants['fixTypes']['removeRange'],'range':_0x311cb4};}__name(createRemoveRangeFix,'createRemoveRangeFix');function createReplaceFix(_0x416aaf){return {'type':constants['fixTypes']['replace'],'text':_0x416aaf};}__name(createReplaceFix,'createReplaceFix');function getStandaloneFix(_0x103358,_0x4c2b47){const _0x134fa6=_0x4c2b47['getIndexFromLoc']({'line':_0x103358['loc']['start']['line'],'column':0x0});let _0x3326f0=_0x103358['range'][-0x3a1*0x7+0x1f13+-0x1*0x5ab];return _0x4c2b47['text']['charAt'](_0x3326f0)==='\x0a'&&(_0x3326f0+=-0x1*0x1d21+0x1*-0x1184+0x2ea6),createRemoveRangeFix(_0x134fa6,_0x3326f0);}__name(getStandaloneFix,'getStandaloneFix');function getMultilineFix(_0x3d48fa,_0x260b51,_0x549604){const _0x7abbb9=_0x3d48fa['split']('\x0a'),_0x2a48ce=_0x7abbb9['findIndex'](_0xbd3968=>_0xbd3968['includes'](_0x260b51));let _0x49a52f;if(_0x2a48ce!==-(-0x12ab*-0x1+-0x19f8+0xaa*0xb)){const _0x106cb1=_0x7abbb9[_0x2a48ce],_0x45f47a=_0x549604(_0x106cb1)['replace'](constants['patterns']['seeLink'],'');if(!_0x45f47a){_0x7abbb9['splice'](_0x2a48ce,-0x61f*-0x1+-0xc*0x33d+0xaea*0x3);const _0xff00d0=_0x7abbb9['filter']((_0x401abc,_0x24c2da)=>{const _0x76c2f1=_0x24c2da===-0x3*-0xa6f+-0x398*0x6+-0x9*0x115||_0x24c2da===_0x7abbb9['length']-(-0x181c+-0xb5*0x35+-0x2*-0x1ecb);if(_0x76c2f1)return !![];return _0x401abc['trim']()!=='*';});_0x49a52f=createReplaceFix(_0xff00d0['join']('\x0a'));}}return _0x49a52f;}__name(getMultilineFix,'getMultilineFix');function getInlineFix(_0x2809c6,_0x3ad20c,_0x4670fc){const _0x49c8ac=_0x3ad20c['indexOf'](_0x4670fc),_0x46de78=_0x2809c6['range'][0xea5+0x7d*-0x3b+0xe2a]+_0x49c8ac,_0xe8e8d8=_0x46de78+_0x4670fc['length'],_0x50f26b=createRemoveRangeFix(_0x46de78,_0xe8e8d8);return _0x50f26b;}__name(getInlineFix,'getInlineFix');function getFixInstruction(_0x39b3fd,_0x2aecb7,_0x5f11cc){const _0x513a35=_0x5f11cc['getText'](_0x39b3fd),_0x57fd9f=_0x2aecb7[-0x121c+-0x3*0x563+0x2245],_0x48f56a=__name(_0x4180ea=>_0x4180ea['replace'](/[/*\s]/g,''),'stripCommentDecorations'),_0x566dc5=_0x48f56a(_0x513a35)['replace'](constants['patterns']['seeLink'],'');let _0x5616f9=getInlineFix(_0x39b3fd,_0x513a35,_0x57fd9f);!_0x566dc5&&(_0x5616f9=getStandaloneFix(_0x39b3fd,_0x5f11cc));if(_0x566dc5&&_0x513a35['includes']('\x0a')){const _0x27d7a6=getMultilineFix(_0x513a35,_0x57fd9f,_0x48f56a);_0x27d7a6&&(_0x5616f9=_0x27d7a6);}return _0x5616f9;}__name(getFixInstruction,'getFixInstruction');
|
|
6
7
|
|
|
7
8
|
export { mustNotUseSeeLinkInDocsIfTypeAvailable as default, ruleName };
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { isNameMatch, isMemberExpression, isIdentifier } from '@flint/infra/analysis';
|
|
3
3
|
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
4
|
+
import { commandNames } from '../../base-repo/constants/common-strings.js';
|
|
4
5
|
|
|
5
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x34f676,_0x28403c)=>__defProp(_0x34f676,'name',{'value':_0x28403c,'configurable':!![]});const ruleName='must-separate-unrelated-tests-into-different-files';const ruleContent='\x0a###\x20**Must**\x20separate\x20unrelated\x20tests\x20into\x20different\x20files\x0a\x0a####\x20Wrong\x0a\x0a//\x20custom-eslint-rules.spec.js\x0aruleTester.run(\x22foo\x22,\x20fooRule,\x20{\x0a\x20\x20\x20\x20…\x0a});\x0a\x0aruleTester.run(\x22bar\x22,\x20barRule,\x20{\x0a\x20\x20\x20\x20…\x0a});\x0a\x0a####\x20Correct\x0a\x0a//\x20foo.spec.js\x0aruleTester.run(\x22foo\x22,\x20fooRule,\x20{\x0a\x20\x20\x20\x20…\x0a});\x0a\x0a//\x20bar.spec.js\x0aruleTester.run(\x22bar\x22,\x20barRule,\x20{\x0a\x20\x20\x20\x20…\x0a});\x0a\x0a####\x20Why\x0a\x0aSeparating\x20unrelated\x20tests\x20improves\x20organization,\x20makes\x20failures\x20easier\x20to\x20isolate.';var mustSeparateUnrelatedTestsIntoDifferentFiles = createEslintRule(ruleName,ruleContent,__name(function create(_0x54bb74){let _0x4f2343=-0x161*0x1c+-0x4*0x8bd+-0x6b*-0xb0;return {'CallExpression'(_0x432857){const _0x2128b1=_0x432857['callee'];(isDirectRunTests(_0x2128b1)||isTesterRun(_0x2128b1))&&(_0x4f2343++,_0x4f2343>-0x1a88+-0x1c3*0x13+0x3c02&&_0x54bb74['report']({'node':_0x432857,'messageId':ruleName}));}};},'create'));function isDirectRunTests(_0x2566ca){return isNameMatch(_0x2566ca,'runTests')||isNameMatch(_0x2566ca,'runEslintTests');}__name(isDirectRunTests,'isDirectRunTests');function isTesterRun(_0x3c32f9){return isMemberExpression(_0x3c32f9)&&isIdentifier(_0x3c32f9['object'])&&_0x3c32f9['object']['name']['toLowerCase']()['includes']('tester')&&isNameMatch(_0x3c32f9['property'],commandNames['run']);}__name(isTesterRun,'isTesterRun');
|
|
6
7
|
|
|
7
8
|
export { mustSeparateUnrelatedTestsIntoDifferentFiles as default, ruleName };
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
|
-
import { isNameMatch, isIdentifier } from '@flint/infra/analysis';
|
|
3
|
+
import { isNameMatch, hasCorrectCountOfGenericParameters, isIdentifier } from '@flint/infra/analysis';
|
|
4
4
|
|
|
5
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
5
|
+
var __defProp=Object['defineProperty'],__name=(_0x4a922f,_0xacfb57)=>__defProp(_0x4a922f,'name',{'value':_0xacfb57,'configurable':!![]});const ruleName='must-specify-second-generic-parameter-in-apipost-and-apiput';const ruleContent='\x0a###\x20**Must**\x20specify\x20second\x20generic\x20parameter\x20in\x20apiPost\x20and\x20apiPut\x0a\x0a####\x20Wrong\x0a\x0aconst\x20foo\x20=\x20apiPost<bar>(baz,\x20qux)\x20{}\x0a\x0a####\x20Correct\x0a\x0aconst\x20foo\x20=\x20apiPost<bar,\x20baz>(baz,\x20qux)\x20{}\x0a\x0a####\x20Why\x0a\x0aAdds\x20an\x20additional\x20level\x20of\x20type\x20checking\x20to\x20prevent\x20further\x20errors\x20and\x20type\x20inconsistencies.';var mustSpecifySecondGenericParameterInApipostAndApiput = createEslintRule(ruleName,ruleContent,__name(function create(_0x16d899){return {'CallExpression'(_0x593d67){const _0x4f30f4=isNameMatch(_0x593d67['callee'],'apiPost')&&!hasCorrectCountOfGenericParameters(_0x593d67),_0x3eacb5=isNameMatch(_0x593d67['callee'],'apiPut')&&!hasCorrectCountOfGenericParameters(_0x593d67);isIdentifier(_0x593d67['callee'])&&(_0x4f30f4||_0x3eacb5)&&_0x16d899['report']({'node':_0x593d67,'messageId':ruleName});}};},'create'));
|
|
6
6
|
|
|
7
7
|
export { mustSpecifySecondGenericParameterInApipostAndApiput as default, ruleContent, ruleName };
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
3
|
import { nodeTypes, iterateDescendants, isStringLiteral } from '@flint/infra/analysis';
|
|
4
|
+
import { colorNames } from '../../base-repo/constants/tools-constants.js';
|
|
4
5
|
|
|
5
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x4a79d1,_0x339a77)=>__defProp(_0x4a79d1,'name',{'value':_0x339a77,'configurable':!![]});const ruleName='must-use-color-variables-instead-of-hardcoded-values';const ruleContent='\x0a###\x20**Must**\x20use\x20color\x20variables\x20instead\x20of\x20hardcoded\x20values.\x0a\x0a####\x20Wrong\x0a\x0a<div\x20className=\x22bg-[#CBD6E2]\x22>Content</div>\x0a\x0a####\x20Correct\x0a\x0a<div\x20className=\x22bg-background\x22>Content</div>\x0a\x0a####\x20Why\x0a\x0aUsing\x20CSS\x20variables\x20for\x20colors\x20enhances\x20maintainability,\x20ensures\x20consistency\x20across\x20the\x20design,\x20and\x20simplifies\x20the\x20process\x20of\x20updating\x20themes\x20or\x20color\x20schemes.';var mustUseColorVariablesInsteadOfHardcodedValues = createEslintRule(ruleName,ruleContent,__name(function create(_0x5798d6){const _0x26164f=_0x5798d6['sourceCode'];return {'JSXAttribute'(_0x336011){if(_0x336011['name']['type']!==nodeTypes['JSXIdentifier']||_0x336011['name']['name']!==attributeName||!_0x336011['value'])return;handleNode(_0x5798d6,_0x336011['value']);for(const _0x3f9f01 of iterateDescendants(_0x336011['value'],_0x26164f['visitorKeys'])){handleNode(_0x5798d6,_0x3f9f01['value']);}}};},'create'));function handleNode(_0x2c10de,_0x3866b7){if(isStringLiteral(_0x3866b7))handleClassNames(_0x2c10de,_0x3866b7,_0x3866b7['value']);else _0x3866b7['type']===nodeTypes['templateLiteral']&&handleClassNames(_0x2c10de,_0x3866b7,buildMaskedTemplateLiteral(_0x3866b7));}__name(handleNode,'handleNode');function handleClassNames(_0x565ea7,_0x178003,_0x452e67){const _0x6a1950=_0x565ea7['sourceCode'];for(const _0x117c37 of _0x452e67['matchAll'](regexes['classWithArbitraryValue'])){const _0x222977=_0x117c37[-0x112*0x19+-0x10c8+0x2b8b],_0x2079a1=_0x222977['slice'](0x1*-0x4a9+-0xd6*0x2d+-0x1ec*-0x16,-(-0x8*-0x484+0x36*-0x4a+-0x1483));if(twColorNames['has'](_0x2079a1)||Object['values'](regexes)['some'](_0x3cdee0=>_0x3cdee0['test'](_0x2079a1))){const _0xb1cb7e=_0x117c37[0x1*-0x2f5+-0x1c5b+0x1f50],_0x4f76c6=_0x178003['range'][-0x1164+-0x35*0xd+0x1415]+(0xfaa*-0x2+0x151e+0xa37)+_0x117c37['index']+_0xb1cb7e['indexOf'](_0x222977),_0x227b68=_0x6a1950['getLocFromIndex'](_0x4f76c6),_0x4d5ad9=_0x6a1950['getLocFromIndex'](_0x4f76c6+_0x222977['length']);_0x565ea7['report']({'node':_0x178003,'messageId':ruleName,'loc':{'start':_0x227b68,'end':_0x4d5ad9}});}}}__name(handleClassNames,'handleClassNames');const attributeName='className',twColorNames=new Set(Object['values'](colorNames)),regexes={'classWithArbitraryValue':/\b(?:\w+:)*(?:text|bg|border(?:-[trblyx])?)-(\[[^\]]+\])/g,'hexColor':/^#[0-9a-f]{3,6}$/i,'colorFunction':/^(rgb|rgba|hsl|hsla|color)\(.+\)$/i};function buildMaskedTemplateLiteral(_0x33d940){return _0x33d940['quasis']['map']((_0x351bfe,_0x35095d)=>{const _0x5af330=_0x33d940['expressions'][_0x35095d];return [_0x351bfe['value']['raw'],_0x5af330?'${'+'\x20'['repeat'](_0x5af330['range'][0x14bc+0x1df3+0x2*-0x1957]-_0x5af330['range'][-0xebe*0x1+-0x1215+0x20d3])+'}':'']['join']('');})['join']('');}__name(buildMaskedTemplateLiteral,'buildMaskedTemplateLiteral');
|
|
6
7
|
|
|
7
8
|
export { mustUseColorVariablesInsteadOfHardcodedValues as default, ruleName };
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
|
-
import { isJSXIdentifier, isJSXExpressionContainer, isTemplateLiteral,
|
|
3
|
+
import { isJSXIdentifier, isJSXExpressionContainer, isTemplateLiteral, nodeTypes, isStringLikeTypeNode, isMemberCallExpression, isArrayMethodCallExpression } from '@flint/infra/analysis';
|
|
4
4
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
5
|
+
import { commonIdNames } from '../../base-repo/constants/common-strings.js';
|
|
5
6
|
|
|
6
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
7
|
+
var __defProp=Object['defineProperty'],__name=(_0x750217,_0x15eb4f)=>__defProp(_0x750217,'name',{'value':_0x15eb4f,'configurable':!![]});const ruleName='must-use-functions-for-component-ids';const ruleContent='\x0a###\x20**Must**\x20use\x20functions\x20for\x20component\x20ids.\x0a\x0a####\x20Wrong\x0a\x0aimport\x20{\x20elements\x20}\x20from\x20\x22@/meta/constants/elements.ts\x22\x0a\x0aexport\x20function\x20Foo({\x20id\x20})\x20{\x0a\x20\x20\x20\x20return\x20<div\x20id={elements.fooElementId\x20+\x20id}></div>\x0a}\x0a\x0a####\x20Correct\x0a\x0aimport\x20{\x20getFooId\x20}\x20from\x20\x22./Foo.funcs.ts\x22\x0a\x0aexport\x20function\x20Foo({\x20id\x20})\x20{\x0a\x20\x20\x20\x20return\x20<div\x20id={getFooId(id)}></div>\x0a}\x0a\x0a####\x20Why\x0a\x0aUsing\x20functions\x20instead\x20of\x20direct\x20concatenation\x20helps\x20with\x20consistency\x20and\x20prevents\x20bugs.';var mustUseFunctionsForComponentIds = createEslintRule(ruleName,ruleContent,__name(function create(_0x291249){const _0xbd7a7e=ESLintUtils['getParserServices'](_0x291249);return {'JSXAttribute'(_0x1ef963){if(!isJSXIdentifier(_0x1ef963['name'])||_0x1ef963['name']['name']!==commonIdNames['id']||!_0x1ef963['value']||!isJSXExpressionContainer(_0x1ef963['value']))return;const _0x5b56f3=_0x1ef963['value']['expression'];(isConcatenationUsingOperator(_0x5b56f3,_0xbd7a7e)||isTemplateLiteral(_0x5b56f3)&&_0x5b56f3['expressions']['length']>-0x15*0x1a6+0x2b*-0xcd+0x450d||isConcatenationUsingStringMethod(_0x5b56f3,_0xbd7a7e)||isConcatenationUsingArrayMethod(_0x5b56f3,_0xbd7a7e)||isPossibleConcatenationUsingArrayMethod(_0x5b56f3,_0xbd7a7e))&&_0x291249['report']({'node':_0x1ef963,'messageId':ruleName});}};},'create'));const concatenationMethods={'string':['concat'],'array':{'definitely':['join'],'possibly':['reduce','reduceRight']}};function isConcatenationUsingOperator(_0x30f83b,_0x52e5a6){return _0x30f83b['type']===nodeTypes['binaryExpression']&&_0x30f83b['operator']==='+'&&isStringLikeTypeNode(_0x30f83b,_0x52e5a6);}__name(isConcatenationUsingOperator,'isConcatenationUsingOperator');function isConcatenationUsingStringMethod(_0x84ae74,_0x217212){return isMemberCallExpression(_0x84ae74)&&isStringLikeTypeNode(_0x84ae74['callee']['object'],_0x217212)&&!_0x84ae74['callee']['computed']&&concatenationMethods['string']['includes'](_0x84ae74['callee']['property']['name']);}__name(isConcatenationUsingStringMethod,'isConcatenationUsingStringMethod');function isConcatenationUsingArrayMethod(_0x1eae4c,_0x5ddbec){return isArrayMethodCallExpression(_0x1eae4c,_0x5ddbec,concatenationMethods['array']['definitely']);}__name(isConcatenationUsingArrayMethod,'isConcatenationUsingArrayMethod');function isPossibleConcatenationUsingArrayMethod(_0x1f5e1f,_0x3eb1a6){return isArrayMethodCallExpression(_0x1f5e1f,_0x3eb1a6,concatenationMethods['array']['possibly'])&&isStringLikeTypeNode(_0x1f5e1f,_0x3eb1a6);}__name(isPossibleConcatenationUsingArrayMethod,'isPossibleConcatenationUsingArrayMethod');
|
|
7
8
|
|
|
8
9
|
export { mustUseFunctionsForComponentIds as default, ruleName };
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
3
|
import { isMemberExpression, isIdentifier, isCallExpression } from '@flint/infra/analysis';
|
|
4
|
+
import { collectionMethodNames } from '../../base-repo/constants/common-strings.js';
|
|
4
5
|
|
|
5
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x3d08c8,_0x1231f9)=>__defProp(_0x3d08c8,'name',{'value':_0x1231f9,'configurable':!![]});const ruleName='must-use-odata-builder';const ruleContent='\x0a###\x20Must\x20use\x20getODataBuilder\x20instead\x20of\x20creating\x20oDataConfig\x20manually\x0a\x0a####\x20Wrong\x0a\x0aconst\x20oDataConfig\x20=\x20getEmptyODataConfig();\x0aoDataConfig.filters?.push({\x0a\x20\x20\x20\x20leftHand:\x20\x22userId\x22,\x0a\x20\x20\x20\x20rightHand:\x20userId,\x0a\x20\x20\x20\x20type:\x20oDataFilterTypes.guid,\x0a\x20\x20\x20\x20operator:\x20oDataOperatorConst.equal,\x0a});\x0a\x0a####\x20Correct\x0a\x0aconst\x20oDataConfig\x20=\x20getODataBuilder().filter(\x22userId\x22,\x20userId,\x20oDataOperatorConst.equal).build();\x0a\x0a####\x20Why\x0a\x0aUsing\x20ODataBuilder\x20provides\x20a\x20standardized\x20approach\x20for\x20creating\x20OData\x20queries,\x20reducing\x20errors,\x20improving\x20readability,\x20and\x20ensuring\x20consistent\x20filter\x20construction\x20throughout\x20the\x20codebase.';var mustUseOdataBuilder = createEslintRule(ruleName,ruleContent,__name(function create(_0x1e78d1){const _0x442f7b=new Map(),_0x1ad5f7=new Set();return {'VariableDeclarator'(_0x7ce1f0){if(!isIdentifier(_0x7ce1f0['id']))return;const _0x1262cf=_0x7ce1f0['init'];if(!_0x1262cf||!isCallExpression(_0x1262cf))return;const _0x5e18ea=_0x1262cf['callee'];if(!isIdentifier(_0x5e18ea)||_0x5e18ea['name']!=='getEmptyODataConfig')return;_0x442f7b['set'](_0x7ce1f0['id']['name'],_0x7ce1f0);},'CallExpression'(_0x258094){if(!isMemberExpression(_0x258094['callee']))return;const _0x36ef7c=_0x258094['callee']['object'];if(!isMemberExpression(_0x36ef7c))return;const _0x9dd6f3=_0x36ef7c['object'],_0x42e24a=_0x36ef7c['property'];if(!isIdentifier(_0x9dd6f3)||!isIdentifier(_0x42e24a))return;_0x442f7b['has'](_0x9dd6f3['name'])&&_0x42e24a['name']==='filters'&&isIdentifier(_0x258094['callee']['property'])&&_0x258094['callee']['property']['name']===collectionMethodNames['push']&&(_0x1ad5f7['add'](_0x9dd6f3['name']),_0x1e78d1['report']({'node':_0x258094,'messageId':ruleName}));},'Program:exit'(){for(const [_0x1d7c75,_0x19d29b]of _0x442f7b){!_0x1ad5f7['has'](_0x1d7c75)&&_0x1e78d1['report']({'node':_0x19d29b,'messageId':ruleName});}}};},'create'));
|
|
6
7
|
|
|
7
8
|
export { mustUseOdataBuilder as default, ruleName };
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
3
|
import { isIdentifier, isMemberExpression } from '@flint/infra/analysis';
|
|
4
|
+
import { jsBasicTypes } from '../../base-repo/constants/basic-types.js';
|
|
4
5
|
|
|
5
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x4d74d9,_0x368fb8)=>__defProp(_0x4d74d9,'name',{'value':_0x368fb8,'configurable':!![]});const ruleName='must-use-only-crud-operations';const ruleContent='\x0a###\x20Must\x20use\x20only\x20CRUD\x20operations\x20for\x20working\x20with\x20resources.\x0a\x0a####\x20Wrong\x0a\x0aawait\x20createResource(foo);\x0a\x0aawait\x20bar.createResource(foo);\x0a\x0a####\x20Correct\x0a\x0aawait\x20crudCreate(foo);\x0a\x0a####\x20Why\x0a\x0aUsing\x20CRUD\x20operations\x20helps\x20maintain\x20clean\x20architecture,\x20improves\x20readability,\x20and\x20simplifies\x20code\x20understanding\x20and\x20extension.',createResource='createResource';var mustUseOnlyCrudOperations = createEslintRule(ruleName,ruleContent,__name(function create(_0x223c56){const _0x3ab7c5=_0x223c56['options'][-0x25*-0xd1+0x621*-0x5+0x70]??{'restrictedFunctions':[typeof createResource]},_0x13aa16=_0x3ab7c5['restrictedFunctions'];return {'CallExpression'(_0x220b48){const _0x47f2d2=_0x220b48['callee'];let _0x15f69f;if(isIdentifier(_0x47f2d2))_0x15f69f=_0x47f2d2['name'];else isMemberExpression(_0x47f2d2)&&isIdentifier(_0x47f2d2['property'])&&(_0x15f69f=_0x47f2d2['property']['name']);_0x15f69f!==void(-0x2*0xa4f+0xb*0x347+-0x1b7*0x9)&&_0x13aa16['includes'](_0x15f69f)&&_0x223c56['report']({'node':_0x220b48,'messageId':ruleName});}};},'create'),{'schema':[{'type':jsBasicTypes['object'],'properties':{'restrictedFunctions':{'type':jsBasicTypes['array'],'items':{'type':jsBasicTypes['string']}}},'additionalProperties':![]}],'defaultOptions':[{'restrictedFunctions':[typeof createResource]}]});
|
|
6
7
|
|
|
7
8
|
export { mustUseOnlyCrudOperations as default, ruleName };
|
package/packages/flint/rules/must-use-resource-provider-functions-to-get-resources-on-server.js
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
|
+
import { isStringType } from '@flint/infra/analysis/string-analysis';
|
|
4
|
+
import { nodeTypes, getSpecifierName } from '@flint/infra/analysis';
|
|
5
|
+
import { folders } from '../../base-repo/app-constants/project-paths.js';
|
|
6
|
+
import { commonFileSuffixes } from '../../base-repo/constants/extensions.js';
|
|
7
|
+
import { commonProjectPartNames } from '../../base-repo/constants/common-strings.js';
|
|
8
|
+
|
|
9
|
+
var __defProp=Object['defineProperty'],__name=(_0x3965ae,_0x3da7ed)=>__defProp(_0x3965ae,'name',{'value':_0x3da7ed,'configurable':!![]});const ruleName='must-use-resource-provider-functions-to-get-resources-on-server';const ruleContent='\x0a###\x20**Must**\x20use\x20resource-provider\x20functions\x20to\x20get\x20resources\x20on\x20server\x0a\x0aFunctions\x20from\x20db\x20can\x20be\x20used\x20only\x20in\x20resource\x20provider\x0a\x0a####\x20Wrong\x0a\x0aimport\x20{\x20getResourcesByName\x20}\x20from\x20\x22@server/fd/fd-toolbox/db/db\x22;\x0a\x0aconst\x20resources\x20=\x20getResourcesByName(\x22Foo\x22);\x0a\x0a####\x20Correct\x0a\x0aimport\x20{\x20getResources\x20}\x20from\x20\x22@meta/server/services/resource-provider\x22;\x0a\x0aconst\x20resources\x20=\x20getResources(\x22Foo\x22,\x20getUuid());\x0a\x0a####\x20Why\x0a\x0aHelps\x20with\x20standardizing\x20getting\x20resources\x20and\x20preventing\x20bugs.',forbiddenImportSources=['@server/fd/fd-toolbox/db/db','@meta/server/db/db'],lowLevelDbFunctions=new Set(['getResourcesByName','getResourcesWithOData','findResourceById']),exemptionPatterns=['level2/meta/server/','resource-provider',commonFileSuffixes['dotSpecDot'],folders['testInfra'],'seeding','migrations'];function isExemptFile(_0x4b8202){if(!_0x4b8202)return ![];return _0x4b8202['endsWith']('-db.ts')||exemptionPatterns['some'](_0x2aaf75=>_0x4b8202['includes'](_0x2aaf75));}__name(isExemptFile,'isExemptFile');var mustUseResourceProviderFunctionsToGetResourcesOnServer = createEslintRule(ruleName,ruleContent,_0xc325b0=>{if(isExemptFile(_0xc325b0['filename']))return {};return {'ImportDeclaration'(_0x3297a4){const _0x5e07e1=_0x3297a4['source']['value'],_0x3d7830=!isStringType(_0x5e07e1)||_0x3297a4['importKind']===commonProjectPartNames['type']||!forbiddenImportSources['includes'](_0x5e07e1);if(_0x3d7830)return;const _0x5312cb=(_0x3297a4['specifiers']||[])['filter'](_0x2437f2=>_0x2437f2['type']===nodeTypes['importSpecifier']);for(const _0xa580c2 of _0x5312cb){const _0x3ca09d=getSpecifierName(_0xa580c2['imported']);_0x3ca09d&&lowLevelDbFunctions['has'](_0x3ca09d)&&_0xc325b0['report']({'node':_0xa580c2,'messageId':ruleName});}}};});
|
|
10
|
+
|
|
11
|
+
export { mustUseResourceProviderFunctionsToGetResourcesOnServer as default, ruleName };
|
|
@@ -3,6 +3,6 @@ import { ESLintUtils } from '@typescript-eslint/utils';
|
|
|
3
3
|
import { getFileName } from '@flint/infra/analysis';
|
|
4
4
|
import { url, ruleTypes } from '@flint/infra/constants/rules-meta';
|
|
5
5
|
|
|
6
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x143a95,_0x30e2b8)=>__defProp(_0x143a95,'name',{'value':_0x30e2b8,'configurable':!![]});const ruleName='filename-kebab-case';const createRule=ESLintUtils['RuleCreator'](_0x495d49=>''+url+_0x495d49),virtualFilename='input-file',ignoredFilenames=['README','README.md','LICENSE','Makefile','.env','.gitignore','.eslintrc.js','.prettierrc','.prettierignore'];function isKebabCase(_0xb63ae0){let _0x36b601;if(ignoredFilenames['includes'](_0xb63ae0))_0x36b601=!![];else {const _0x4026a1=getFileName(_0xb63ae0),_0x2f943f=_0x4026a1['split']('.')[-0x290*0xb+-0x5fb*-0x2+0x86*0x1f];!_0x2f943f?_0x36b601=![]:_0x36b601=/^[a-z0-9]+([-.][a-z0-9]+)*(\.[a-z]+)?$/['test'](_0x2f943f);}return _0x36b601;}__name(isKebabCase,'isKebabCase');const filenameKebabCase=createRule({'name':'filename-kebab-case','meta':{'type':ruleTypes['problem'],'docs':{'description':'Enforce\x20kebab\x20case\x20for\x20file\x20names'},'messages':{'useKebabCase':'filename-kebab-case\x0a###\x20**Must**\x20use\x20kebab-case\x20for\x20file\x20names.\x0a\x0aAvoid\x20camelCase\x20or\x20PascalCase\x20in\x20filenames.\x0a\x0a####\x20Wrong\x0a\x0aMyComponent.ts\x0a\x0a####\x20Correct\x0a\x0amy-component.ts\x0a\x0a####\x20Why\x0a\x0aFilenames\x20should\x20use\x20kebab-case\x20(lowercase\x20and\x20dashes)\x20to\x20maintain\x20consistency\x20through\x20codebase.'},'schema':[]},'create'(_0x1fbc18){const _0x5be7c8=getFileName(_0x1fbc18['filename']);return _0x5be7c8!==virtualFilename&&!isKebabCase(_0x5be7c8)&&_0x1fbc18['report']({'loc':{'line':0x1,'column':0x0},'messageId':'useKebabCase','data':{'fileName':_0x5be7c8}}),{};},'defaultOptions':[]});
|
|
7
7
|
|
|
8
8
|
export { filenameKebabCase as default, ruleName };
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
import { AST_TOKEN_TYPES, ESLintUtils } from '@typescript-eslint/utils';
|
|
3
3
|
import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
|
|
4
4
|
|
|
5
|
-
const ruleName='must-add-empty-line-before-assert-act-arrange';const ruleId='mustAddEmptyLineBeforeAssertActArrange';const constants={'meta':{'type':ruleTypes['problem'],'docs':{'description':ruleName},'messages':{[ruleId]:ruleName+'\x0a###\x20**Must**\x20add\x20empty\x20line\x20before\x20Assert,\x20Act,\x20Arrange.\x0a\x0a####\x20Wrong\x0a\x0aconst\x20foo\x20=\x20\x22Foo\x22;\x0a//\x20Act\x0aconst\x20result\x20=\x20actual.result;\x0a\x0a####\x20Correct\x0a\x0aconst\x20foo\x20=\x20\x22Foo\x22;\x0a\x0a//\x20Act\x0aconst\x20result\x20=\x20actual.result;\x0a\x0a####\x20Why\x0a\x0aThis\x20improves\x20readability\x20of\x20tests.'},'fixable':'whitespace','schema':[]},'aaaRegex':/^\s*(Arrange|Act|Assert)(,\s*(Arrange|Act|Assert))*\b/i,'tokens':{'openingBrace':'{','punctuator':AST_TOKEN_TYPES['Punctuator']}},createRule=ESLintUtils['RuleCreator'](
|
|
5
|
+
const ruleName='must-add-empty-line-before-assert-act-arrange';const ruleId='mustAddEmptyLineBeforeAssertActArrange';const constants={'meta':{'type':ruleTypes['problem'],'docs':{'description':ruleName},'messages':{[ruleId]:ruleName+'\x0a###\x20**Must**\x20add\x20empty\x20line\x20before\x20Assert,\x20Act,\x20Arrange.\x0a\x0a####\x20Wrong\x0a\x0aconst\x20foo\x20=\x20\x22Foo\x22;\x0a//\x20Act\x0aconst\x20result\x20=\x20actual.result;\x0a\x0a####\x20Correct\x0a\x0aconst\x20foo\x20=\x20\x22Foo\x22;\x0a\x0a//\x20Act\x0aconst\x20result\x20=\x20actual.result;\x0a\x0a####\x20Why\x0a\x0aThis\x20improves\x20readability\x20of\x20tests.'},'fixable':'whitespace','schema':[]},'aaaRegex':/^\s*(Arrange|Act|Assert)(,\s*(Arrange|Act|Assert))*\b/i,'tokens':{'openingBrace':'{','punctuator':AST_TOKEN_TYPES['Punctuator']}},createRule=ESLintUtils['RuleCreator'](_0x39e3e8=>''+url+_0x39e3e8),mustAddEmptyLineBeforeAssertActArrange=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x40a015){const _0x21f14a=_0x40a015['sourceCode'];return {'Program'(){const _0x2325d9=_0x21f14a['getAllComments']();_0x2325d9['forEach'](_0x221513=>{const _0x2aa50c=_0x21f14a['getTokenBefore'](_0x221513,{'includeComments':!![]}),_0x3215f0=constants['aaaRegex']['test'](_0x221513['value'])&&_0x221513['loc']['start']['line']!==0x1734+0xfbb*-0x2+0x843&&_0x2aa50c&&!(_0x2aa50c['type']===constants['tokens']['punctuator']&&_0x2aa50c['value']===constants['tokens']['openingBrace'])&&_0x221513['loc']['start']['line']-_0x2aa50c['loc']['end']['line']===0x1*0x7ca+-0x1c31+0x1468;_0x3215f0&&_0x40a015['report']({'loc':_0x221513['loc'],'messageId':ruleId,'fix'(_0xb778ed){const _0x172319=_0x21f14a['getIndexFromLoc']({'line':_0x221513['loc']['start']['line'],'column':0x0});return _0xb778ed['insertTextBeforeRange']([_0x172319,_0x172319],'\x0a');}});});}};}});
|
|
6
6
|
|
|
7
7
|
export { mustAddEmptyLineBeforeAssertActArrange as default, ruleId, ruleName };
|
|
@@ -4,6 +4,6 @@ import { getFileNamePrefix, nodeTypes, getExportedFunctionNames } from '@flint/i
|
|
|
4
4
|
import { kebabToCamelCasePattern } from '@flint/infra/constants/rules-regex';
|
|
5
5
|
import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
|
|
6
6
|
|
|
7
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
7
|
+
var __defProp=Object['defineProperty'],__name=(_0x32fe14,_0x269dc9)=>__defProp(_0x32fe14,'name',{'value':_0x269dc9,'configurable':!![]});const ruleName='must-add-prefix-to-po-functions';const constants={'messageIds':{'mustAddPrefixToPoFunctions':'mustAddPrefixToPoFunctions'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Ensure\x20all\x20exported\x20functions\x20in\x20PO\x20files\x20have\x20proper\x20prefix.'},'messages':{'mustAddPrefixToPoFunctions':'must-add-prefix-to-po-functions\x0a###\x20**Must**\x20add\x20prefix\x20to\x20functions\x20in\x20Page\x20Object\x20files.\x0a\x0a####\x20Wrong\x0a\x0aexport\x20function\x20getFoo()\x20{...}\x0a\x0a####\x20Correct\x0a\x0aexport\x20function\x20browserPoGetFoo()\x20{...}\x0a\x0a####\x20Why\x0a\x0aThis\x20improves\x20clarity\x20and\x20helps\x20with\x20naming\x20conflicts.'},'schema':[]},'regexPatterns':{'filenamePrefix':/^(.+)-po\.[^.]+$/}},createRule=ESLintUtils['RuleCreator'](_0x1849c8=>new URL(_0x1849c8,url)['href']);function toCamelCase(_0x30cc15){return _0x30cc15['replace'](kebabToCamelCasePattern,(_0x5cf0b6,_0x3c8e0c)=>_0x3c8e0c['toUpperCase']());}__name(toCamelCase,'toCamelCase');function checkFunctionName(_0x50c133,_0x491c39,_0xcf46e4,_0x1d8d86){const _0x5736e2=toCamelCase(_0x491c39)+'Po';!_0x50c133['startsWith'](_0x5736e2)&&_0xcf46e4['report']({'node':_0x1d8d86,'messageId':constants['messageIds']['mustAddPrefixToPoFunctions'],'data':{'prefix':_0x5736e2,'name':_0x50c133}});}__name(checkFunctionName,'checkFunctionName');const mustAddPrefixToPoFunctions=createRule({'name':ruleName,'meta':constants['meta'],'create'(_0x3c8cac){const _0x34efb4=_0x3c8cac['filename'],_0x5ae00d=getFileNamePrefix(_0x34efb4,constants['regexPatterns']['filenamePrefix']);if(!_0x5ae00d)return {};return {'ExportNamedDeclaration'(_0x27f49d){for(const _0x45e2b3 of getExportedFunctionNames(_0x27f49d)){checkFunctionName(_0x45e2b3,_0x5ae00d,_0x3c8cac,_0x27f49d);}},'ExportDefaultDeclaration'(_0x3a66bf){const _0x34c71c=_0x3a66bf['declaration'];_0x34c71c['type']===nodeTypes['functionDeclaration']&&_0x34c71c['id']&&checkFunctionName(_0x34c71c['id']['name'],_0x5ae00d,_0x3c8cac,_0x3a66bf);}};},'defaultOptions':[]});
|
|
8
8
|
|
|
9
9
|
export { mustAddPrefixToPoFunctions as default, ruleName };
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
3
|
|
|
4
|
-
const ruleName='must-avoid-non-null-assertions';const ruleContent='\x0a###\x20**Must**\x20avoid\x20using\x20wrong\x20non-null\x20assertions.\x0a\x0a####\x20Wrong\x0a\x0afunction\x20foo(bar?:\x20string)\x20{\x0a\x20\x20\x20\x20baz(bar!)\x0a}\x0a\x0afunction\x20baz(bar:\x20string)\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0a####\x20Correct\x0a\x0afunction\x20foo(bar?:\x20string)\x20{\x0a\x20\x20\x20\x20baz(bar)\x0a}\x0a\x0afunction\x20baz(bar?:\x20string)\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0aor\x0a\x0afunction\x20foo(bar?:\x20string)\x20{\x0a\x20\x20\x20\x20if\x20(bar)\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20baz(bar)\x0a\x20\x20\x20\x20}\x0a}\x0a\x0afunction\x20baz(bar:\x20string)\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0a####\x20Why\x0a\x0aUsing\x20non-null\x20assertions\x20(!)\x20bypasses\x20TypeScript\x27s\x20type\x20checking\x20and\x20can\x20lead\x20to\x20runtime\x20errors\x20if\x20the\x20value\x20is\x20actually\x20null\x20or\x20undefined.\x20Instead\x20make\x20sure\x20if\x20the\x20value\x20is\x20actually\x20must\x20be\x20nullable\x20in\x20the\x20parent\x20component,\x20or\x20check\x20it\x20with\x20if\x20statement';var mustAvoidNonNullAssertions = createEslintRule(ruleName,ruleContent,
|
|
4
|
+
const ruleName='must-avoid-non-null-assertions';const ruleContent='\x0a###\x20**Must**\x20avoid\x20using\x20wrong\x20non-null\x20assertions.\x0a\x0a####\x20Wrong\x0a\x0afunction\x20foo(bar?:\x20string)\x20{\x0a\x20\x20\x20\x20baz(bar!)\x0a}\x0a\x0afunction\x20baz(bar:\x20string)\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0a####\x20Correct\x0a\x0afunction\x20foo(bar?:\x20string)\x20{\x0a\x20\x20\x20\x20baz(bar)\x0a}\x0a\x0afunction\x20baz(bar?:\x20string)\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0aor\x0a\x0afunction\x20foo(bar?:\x20string)\x20{\x0a\x20\x20\x20\x20if\x20(bar)\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20baz(bar)\x0a\x20\x20\x20\x20}\x0a}\x0a\x0afunction\x20baz(bar:\x20string)\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0a####\x20Why\x0a\x0aUsing\x20non-null\x20assertions\x20(!)\x20bypasses\x20TypeScript\x27s\x20type\x20checking\x20and\x20can\x20lead\x20to\x20runtime\x20errors\x20if\x20the\x20value\x20is\x20actually\x20null\x20or\x20undefined.\x20Instead\x20make\x20sure\x20if\x20the\x20value\x20is\x20actually\x20must\x20be\x20nullable\x20in\x20the\x20parent\x20component,\x20or\x20check\x20it\x20with\x20if\x20statement';var mustAvoidNonNullAssertions = createEslintRule(ruleName,ruleContent,_0x3466c7=>{return {'TSNonNullExpression'(_0x207c16){_0x3466c7['report']({'node':_0x207c16,'messageId':ruleName});}};});
|
|
5
5
|
|
|
6
6
|
export { mustAvoidNonNullAssertions as default, ruleName };
|
|
@@ -3,6 +3,6 @@ import { ESLintUtils } from '@typescript-eslint/utils';
|
|
|
3
3
|
import { nodeTypes, getFileName } from '@flint/infra/analysis';
|
|
4
4
|
import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
|
|
5
5
|
|
|
6
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x4647ef,_0x45fedc)=>__defProp(_0x4647ef,'name',{'value':_0x45fedc,'configurable':!![]});const ruleName='must-create-assert-functions-in-asserts-files';const constants={'messageIds':{'mustCreateAssertFunctionsInAssertsFiles':'must-create-assert-functions-in-asserts-files'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Must\x20create\x20assert\x20functions\x20in\x20asserts\x20files.'},'messages':{'mustCreateAssertFunctionsInAssertsFiles':'must-create-assert-functions-in-asserts-files\x0a###\x20**Must**\x20create\x20assert\x20functions\x20in\x20asserts\x20files.\x0a\x0a####\x20Wrong\x0a\x0a//\x20table-po.ts\x0aexport\x20function\x20assertTableGetFoo()\x20{...}\x0a\x0a####\x20Correct\x0a\x0a//\x20table-asserts.ts\x0aexport\x20function\x20assertTableGetFoo()\x20{...}\x0a\x0a####\x20Why\x0a\x0aThis\x20helps\x20separate\x20asserts\x20from\x20other\x20functions.'},'schema':[]}},createRule=ESLintUtils['RuleCreator'](_0x3d5a4b=>''+url+_0x3d5a4b);function checkFunctionName(_0x49f3e9,_0x32d141){let _0x1bd8d9=![];const _0x49f47a=/(^a|-a)sserts?([.-]|$)/,_0x22afa7=/(^a|A)ssert($|[A-Z])/;return _0x32d141['id']&&_0x32d141['id']['type']===nodeTypes['identifier']&&_0x22afa7['test'](_0x32d141['id']['name'])&&!_0x49f47a['test'](getFileName(_0x49f3e9['filename']))&&(_0x49f3e9['report']({'node':_0x32d141['id'],'messageId':'mustCreateAssertFunctionsInAssertsFiles'}),_0x1bd8d9=!![]),_0x1bd8d9;}__name(checkFunctionName,'checkFunctionName');const mustCreateAssertFunctionsInAssertsFiles=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0xaa0a9a){return {'FunctionDeclaration'(_0x24bd1e){checkFunctionName(_0xaa0a9a,_0x24bd1e);},'FunctionExpression'(_0x5899d9){!checkFunctionName(_0xaa0a9a,_0x5899d9)&&_0x5899d9['parent']['type']===nodeTypes['variableDeclarator']&&checkFunctionName(_0xaa0a9a,_0x5899d9['parent']);},'TSDeclareFunction'(_0x4b547c){checkFunctionName(_0xaa0a9a,_0x4b547c);},'VariableDeclarator'(_0x250eaa){String(_0x250eaa['init']?.['type'])===nodeTypes['arrowFunctionExpression']&&checkFunctionName(_0xaa0a9a,_0x250eaa);}};}});
|
|
7
7
|
|
|
8
8
|
export { mustCreateAssertFunctionsInAssertsFiles as default, ruleName };
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
3
|
-
import { isStringLiteral,
|
|
3
|
+
import { isStringLiteral, isTemplateLiteral, isTestFile, getMethodNameFromCallee } from '@flint/infra/analysis';
|
|
4
4
|
import { url } from '@flint/infra/constants/rules-meta';
|
|
5
5
|
|
|
6
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x244371,_0x1425f0)=>__defProp(_0x244371,'name',{'value':_0x1425f0,'configurable':!![]});const ruleName='must-get-elements-in-tests-only-by-id';const constants={'messageIds':{'useIdSelectorOnly':'useIdSelectorOnly'},'meta':{'type':'suggestion','docs':{'description':'Must\x20get\x20elements\x20in\x20tests\x20only\x20by\x20id\x20or\x20avoid\x20CSS\x20selectors\x20in\x20getBy*\x20methods'},'messages':{'useIdSelectorOnly':'must-get-elements-in-tests-only-by-id\x0a###\x20**Must**\x20get\x20elements\x20in\x20tests\x20only\x20by\x20id.\x0a\x0a####\x20Wrong\x0a\x0aconst\x20button\x20=\x20page.locator(\x22.btn-primary\x22);\x0aawait\x20button.click();\x0a\x0a####\x20Correct\x0a\x0aconst\x20button\x20=\x20page.locator(\x22#foo-button\x22);\x0aawait\x20button.click();\x0a\x0a####\x20Why\x0a\x0aUsing\x20id\x20ensures\x20consistent\x20and\x20reliable\x20test\x20execution,\x20reducing\x20maintenance\x20efforts\x20and\x20preventing\x20flaky\x20tests.\x20Selector-like\x20strings\x20are\x20not\x20allowed\x20in\x20getBy*\x20methods\x20either;\x20use\x20semantic\x20queries\x20there.'},'schema':[]},'testFilePatterns':[/\.test\.(ts|tsx|js|jsx)$/,/\.spec\.(ts|tsx|js|jsx)$/,/tests?\//i],'cssSelectorMethods':new Set(['locator','$','$$','$eval','$$eval','$evalAll','$x','waitForSelector','filter']),'nonCssSelectorMethods':new Set(['getByTestId','getByRole','getByText','getByLabel','getByPlaceholder','getByAltText','getByTitle','getByDisplayValue']),'patterns':{'idOnlySelector':/^\s*#[A-Za-z0-9_-]+\s*$/,'selectorLikeTag':/^[a-z][a-z0-9_-]*(?:[#:>.+~]|\[|\s+[>+~])/i},'selectorLikeStarts':['#','.','[',':','>','+','~','xpath=','css=','//','.//','..//']},createRule=ESLintUtils['RuleCreator'](_0x4e476c=>''+url+_0x4e476c);function getStaticStringValue(_0x1aefe3){let _0x3f06a1;if(isStringLiteral(_0x1aefe3))_0x3f06a1=_0x1aefe3['value'];else isTemplateLiteral(_0x1aefe3)&&_0x1aefe3['expressions']['length']===-0xc5*0x5+-0x256f+0x2948&&(_0x3f06a1=_0x1aefe3['quasis'][-0xfc2+0x1*-0x2199+0x315b]?.['value']['raw']);return _0x3f06a1;}__name(getStaticStringValue,'getStaticStringValue');function isInvalidCssSelector(_0x1fe20f){const _0x5af482=getStaticStringValue(_0x1fe20f);if(!_0x5af482)return ![];return !constants['patterns']['idOnlySelector']['test'](_0x5af482);}__name(isInvalidCssSelector,'isInvalidCssSelector');function isInvalidNonCssSelector(_0x2c72e0){const _0xd1ebba=getStaticStringValue(_0x2c72e0);if(!_0xd1ebba)return ![];const _0x3cd61c=_0xd1ebba['trim']();if(constants['selectorLikeStarts']['some'](_0x2bb410=>_0x3cd61c['startsWith'](_0x2bb410)))return !![];return constants['patterns']['selectorLikeTag']['test'](_0x3cd61c);}__name(isInvalidNonCssSelector,'isInvalidNonCssSelector');const mustGetElementsInTestsOnlyById=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x13bcb8){if(!isTestFile(_0x13bcb8['filename']))return {};return {'CallExpression'(_0x4dde1c){const _0x14e4e0=getMethodNameFromCallee(_0x4dde1c['callee']);if(!_0x14e4e0)return;const _0x435082=_0x4dde1c['arguments'][0x14d7+0x1dca+-0x32a1*0x1];if(!_0x435082)return;if(constants['cssSelectorMethods']['has'](_0x14e4e0)&&isInvalidCssSelector(_0x435082)){_0x13bcb8['report']({'node':_0x435082,'messageId':constants['messageIds']['useIdSelectorOnly']});return;}constants['nonCssSelectorMethods']['has'](_0x14e4e0)&&isInvalidNonCssSelector(_0x435082)&&_0x13bcb8['report']({'node':_0x435082,'messageId':constants['messageIds']['useIdSelectorOnly']});}};}});
|
|
7
7
|
|
|
8
8
|
export { mustGetElementsInTestsOnlyById as default, ruleName };
|
package/packages/flint/rules/naming/must-name-ui-tests-component-condition-expected-result.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
3
|
-
import { getMethodNameFromCallee, nodeTypes } from '@flint/infra/analysis';
|
|
3
|
+
import { getMethodNameFromCallee, nodeTypes, isSimpleMemberExpression } from '@flint/infra/analysis';
|
|
4
4
|
import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
|
|
5
5
|
|
|
6
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x2acd29,_0x306f3c)=>__defProp(_0x2acd29,'name',{'value':_0x306f3c,'configurable':!![]});const ruleName='must-name-ui-tests-component-condition-expected-result';const constants={'messageIds':{'mustNameUiTestsComponentConditionExpectedResult':'mustNameUiTestsComponentConditionExpectedResult'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Must\x20name\x20Ui\x20tests\x20Component\x20-\x20Condition\x20-\x20Expected\x20Result.'},'messages':{'mustNameUiTestsComponentConditionExpectedResult':'must-name-ui-tests-component-condition-expected-result\x0a###\x20**Must**\x20name\x20Ui\x20tests\x20Component\x20-\x20Condition\x20-\x20Expected\x20Result.\x0a\x0aUI\x20test\x20names\x20should\x20follow\x20the\x20format:\x20\x22${Component.name}\x20-\x20…\x20-\x20…\x22.\x0a\x0a####\x20Wrong\x0a\x0atest(\x22Person\x20list\x20test\x22,\x20async\x20({\x20page,\x20baseURL\x20})\x20=>\x20{...});\x0a\x0a####\x20Correct\x0a\x0atest(\x0a\x20\x20\x20\x20`${ResourceList.name}\x20-\x20filtered\x20by\x20name\x20-\x20only\x20those\x20persons\x20appear\x20in\x20table`,\x0a\x20\x20\x20\x20…\x0a);\x0a\x0a//\x20no\x20condition\x0atest(`${ResourceList.name}\x20-\x20displays\x20list\x20of\x20persons`,\x20…);\x0a\x0a####\x20Why\x0a\x0aUsing\x20consistent\x20and\x20descriptive\x20tests\x20names\x20enhances\x20readability\x20and\x20understanding\x20of\x20the\x20test\x20purpose.'},'schema':[]}};function isUiTest(_0x3b2f4f){return getMethodNameFromCallee(_0x3b2f4f['callee'])==='uiTest'||getMethodNameFromCallee(_0x3b2f4f['callee'],'uiTest')==='fixme';}__name(isUiTest,'isUiTest');function report(_0x6fec04,_0x57d515){_0x6fec04['report']({'node':_0x57d515,'messageId':constants['messageIds']['mustNameUiTestsComponentConditionExpectedResult']});}__name(report,'report');function isDash(_0x327d95){return _0x327d95['some'](_0x389afb=>_0x389afb['value']['cooked']['includes']('\x20-\x20'));}__name(isDash,'isDash');function shouldReportUiTestNameError(_0x43725f){let _0x42ae60=![];if(isUiTest(_0x43725f)){if(_0x43725f['arguments'][-0x249*-0x2+0x13*0x7a+-0xda0]?.['type']===nodeTypes['templateLiteral']){const _0x475384=_0x43725f['arguments'][0x1b21*-0x1+-0xfe3*0x2+0x3ae7]['expressions']['some'](isSimpleMemberExpression);_0x42ae60=!_0x475384||!isDash(_0x43725f['arguments'][0x902*-0x1+-0x912+0x1214]['quasis']);}else _0x42ae60=!![];}return _0x42ae60;}__name(shouldReportUiTestNameError,'shouldReportUiTestNameError');const createRule=ESLintUtils['RuleCreator'](_0x30f6d1=>''+url+_0x30f6d1),mustNameUiTestsComponentConditionExpectedResult=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x2b0db8){return {'CallExpression'(_0x2dc1e7){shouldReportUiTestNameError(_0x2dc1e7)&&report(_0x2b0db8,_0x2dc1e7);}};}});
|
|
7
7
|
|
|
8
8
|
export { mustNameUiTestsComponentConditionExpectedResult as default, ruleName };
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
3
|
-
import
|
|
3
|
+
import _0x333991__default from 'path';
|
|
4
4
|
import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
|
|
5
5
|
|
|
6
|
-
const ruleName='must-not-add-files-and-code-in-lib-folder';const constants={'ruleName':'must-not-add-files-and-code-in-lib-folder','messageIds':{'noLibFolder':'noLibFolder'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Must\x20not\x20add\x20files\x20and\x20code\x20in\x20lib\x20folder'},'messages':{'noLibFolder':'must-not-add-files-and-code-in-lib-folder\x0a###\x20**Must\x20not**\x20add\x20files\x20and\x20code\x20in\x20lib\x20folder.\x0a\x0a####\x20Wrong
|
|
6
|
+
const ruleName='must-not-add-files-and-code-in-lib-folder';const constants={'ruleName':'must-not-add-files-and-code-in-lib-folder','messageIds':{'noLibFolder':'noLibFolder'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Must\x20not\x20add\x20files\x20and\x20code\x20in\x20lib\x20folder'},'messages':{'noLibFolder':'must-not-add-files-and-code-in-lib-folder\x0a###\x20**Must\x20not**\x20add\x20files\x20and\x20code\x20in\x20lib\x20folder.\x0a\x0a####\x20Wrong\x0a\x0a//\x20src/lib/foo.ts\x0a\x0a####\x20Correct\x0a\x0a//\x20src/app/foo.ts\x0a\x0a####\x20Why\x0a\x0a/lib/\x20folder\x20is\x20like\x20a\x20trash\x20can.\x20Do\x20not\x20add\x20new\x20code\x20to\x20it.'},'schema':[]},'libPathSegment':'src/lib'},createRule=ESLintUtils['RuleCreator'](_0x20cf05=>''+url+_0x20cf05),mustNotAddFilesAndCodeInLibFolder=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x142e70){const _0x16ca78=_0x142e70['filename']||'',_0x1f0943=_0x333991__default['normalize'](_0x16ca78)['replace'](/\\/g,'/'),_0x53a5bf=_0x1f0943['includes'](constants['libPathSegment']);if(!_0x53a5bf)return {};return {'Program'(_0x4cad18){_0x142e70['report']({'node':_0x4cad18,'messageId':constants['messageIds']['noLibFolder']});}};}});
|
|
7
7
|
|
|
8
8
|
export { mustNotAddFilesAndCodeInLibFolder as default, ruleName };
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { createEslintRule } from '@flint/infra/create-eslint-rule';
|
|
3
|
-
import
|
|
3
|
+
import _0x7f87ea__default from 'fs';
|
|
4
4
|
|
|
5
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
5
|
+
var __defProp=Object['defineProperty'],__name=(_0x52a83f,_0x53c5b5)=>__defProp(_0x52a83f,'name',{'value':_0x53c5b5,'configurable':!![]});const ruleName='must-not-create-funcs-files-for-non-components';const ruleContent='\x0a###\x20**Must\x20not**\x20create\x20funcs-files\x20for\x20non-components\x0a\x0a####\x20Wrong\x0a\x0a//\x20foo.ts\x0aexport\x20const\x20foo\x20=\x20{\x0a\x20\x20\x20\x20bar:\x20{\x20...\x20},\x0a\x20\x20\x20\x20baz:\x20(context)\x20=>\x20{\x20...\x20}\x0a};\x0a\x0a//\x20foo.funcs.ts\x0aexport\x20function\x20qux(value)\x20{\x0a\x20\x20\x20\x20…\x0a}\x0a\x0a####\x20Correct\x0a\x0a//\x20foo.ts\x0aexport\x20const\x20foo\x20=\x20{\x0a\x20\x20\x20\x20bar:\x20{\x20...\x20},\x0a\x20\x20\x20\x20baz:\x20(context)\x20=>\x20{\x20...\x20}\x0a};\x0a\x0aexport\x20function\x20qux(value)\x20{\x0a\x20\x20\x20\x20…\x0a}\x0a\x0a####\x20Why\x0a\x0aThe\x20.funcs.ts\x20pattern\x20is\x20only\x20allowed\x20for\x20React\x20components.\x20For\x20all\x20other\x20code\x20types,\x20keep\x20all\x20related\x20functions\x20in\x20a\x20single\x20file.';var mustNotCreateFuncsFilesForNonComponents = createEslintRule(ruleName,ruleContent,__name(function create(_0xe84bc){return {'Program'(){const _0x1b60ed=_0xe84bc['filename'];if(_0x1b60ed['endsWith'](constants['ends'])){const _0x5c97f9=_0x1b60ed['replace'](constants['ends'],constants['reactComponentEnds']),_0x57a6f6=_0x5c97f9['replace'](/\\/g,'/');!_0x7f87ea__default['existsSync'](_0x57a6f6)&&_0xe84bc['report']({'messageId':ruleName,'loc':{'line':0x1,'column':0x0}});}}};},'create'));const constants={'reactComponentEnds':'.tsx','ends':'.funcs.ts'};
|
|
6
6
|
|
|
7
7
|
export { mustNotCreateFuncsFilesForNonComponents as default, ruleName };
|
|
@@ -3,6 +3,6 @@ import { ESLintUtils } from '@typescript-eslint/utils';
|
|
|
3
3
|
import { nodeTypes, getFunctionName, isHookByName, isComponentLikeFunction, isSmallLambda, isHookCall } from '@flint/infra/analysis';
|
|
4
4
|
import { url } from '@flint/infra/constants/rules-meta';
|
|
5
5
|
|
|
6
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x5b943b,_0x54b693)=>__defProp(_0x5b943b,'name',{'value':_0x54b693,'configurable':!![]});const ruleName='must-not-declare-func-inside-another-func';const constants={'messageIds':{'mustNotDeclareFuncInsideAnotherFunc':'mustNotDeclareFuncInsideAnotherFunc'},'meta':{'type':'suggestion','docs':{'description':'Moving\x20the\x20inner\x20function\x20outside\x20makes\x20it\x20reusable,\x20more\x20efficient,\x20and\x20easier\x20to\x20read.'},'messages':{'mustNotDeclareFuncInsideAnotherFunc':'must-not-declare-func-inside-another-func\x0a###\x20**Must\x20not**\x20declare\x20function\x20inside\x20another\x20function.\x0a\x0aExcept\x20in\x20React\x20components.\x0a\x0a####\x20Wrong\x0a\x0afunction\x20foo()\x20{\x0a\x20\x20\x20\x20const\x20bar\x20=\x20()\x20=>\x20{...};\x0a}\x0a\x0a####\x20Correct\x0a\x0afunction\x20foo()\x20{\x0a\x20\x20\x20\x20bar()\x0a}\x0a\x0afunction\x20bar()\x20{...}\x0a\x0a####\x20Why\x0a\x0aDeclaring\x20functions\x20inside\x20other\x20functions\x20creates\x20a\x20new\x20instance\x20each\x20time,\x20using\x20extra\x20memory\x20and\x20slowing\x20performance\x20if\x20they\x20don’t\x20rely\x20on\x20the\x20outer\x20function’s\x20scope.\x20Moving\x20the\x20inner\x20function\x20outside\x20makes\x20it\x20reusable,\x20more\x20efficient,\x20and\x20easier\x20to\x20read.'},'schema':[]}},createRule=ESLintUtils['RuleCreator'](_0x42029a=>''+url+_0x42029a),mustNotDeclareFuncInsideAnotherFunc=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x552cfc){const _0x41fc49=[],_0x1019fd=new Set([nodeTypes['methodDefinition'],nodeTypes['property'],nodeTypes['callExpression'],nodeTypes['assignmentExpression']]),_0x421608=[nodeTypes['functionDeclaration'],nodeTypes['functionExpression'],nodeTypes['arrowFunctionExpression']]['join'](',');return {[_0x421608]:_0x20e488=>{const _0x3a4ab4=_0x41fc49['at'](-(-0xbf7+0xa0b+-0x1*-0x1ed));_0x3a4ab4&&_0x3a4ab4['nestedFunctions']['push'](_0x20e488),_0x41fc49['push']({'node':_0x20e488,'containsHookCall':![],'nestedFunctions':[]});},'CallExpression':__name(_0x40b354=>{const _0x5df398=_0x41fc49['at'](-(-0x3e*-0x1+0x39+0x76*-0x1));if(!_0x5df398)return;isHookCall(_0x40b354['callee'])&&(_0x5df398['containsHookCall']=!![]);},'CallExpression'),[_0x421608+':exit']:()=>{const _0x5b8731=_0x41fc49['pop']();if(!_0x5b8731)return;const _0x751c8f=getFunctionName(_0x5b8731['node']);if(!_0x751c8f)return;const _0x4326e4=isHookByName(_0x751c8f)&&_0x5b8731['containsHookCall'],_0x4740e2=isComponentLikeFunction(_0x5b8731['node']),_0x18331b=_0x4326e4||_0x4740e2;if(!_0x18331b)for(const _0x15e3b9 of _0x5b8731['nestedFunctions']){const _0x5b2b00=_0x15e3b9['parent']&&_0x1019fd['has'](_0x15e3b9['parent']['type']),_0x418f46=isSmallLambda(_0x15e3b9);!_0x5b2b00&&!_0x418f46&&_0x552cfc['report']({'node':_0x15e3b9,'messageId':constants['messageIds']['mustNotDeclareFuncInsideAnotherFunc']});}}};}});
|
|
7
7
|
|
|
8
8
|
export { mustNotDeclareFuncInsideAnotherFunc as default, ruleName };
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
3
|
-
import * as
|
|
4
|
-
import * as
|
|
3
|
+
import * as _0x333991 from 'path';
|
|
4
|
+
import * as _0x7f87ea from 'fs';
|
|
5
5
|
import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
|
|
6
6
|
|
|
7
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
7
|
+
var __defProp=Object['defineProperty'],__name=(_0x53e0ef,_0x37b077)=>__defProp(_0x53e0ef,'name',{'value':_0x37b077,'configurable':!![]});const ruleName='must-not-import-react';const funcFileRegex=/\.func\.(ts|tsx)$/,forbiddenImports=['react','react-dom','react/jsx-runtime'],constants={'messageIds':{'mustNotImportReact':'mustNotImportReact'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Disallow\x20importing\x20React\x20in\x20*.func.ts\x20files\x20or\x20any\x20dependency\x20that\x20imports\x20React'},'messages':{'mustNotImportReact':'must-not-import-react\x0a###\x20**Must\x20not**\x20import\x20React\x20in\x20func\x20files.\x0a\x0a####\x20Wrong\x0a\x0a//\x20bar.func.ts\x0aimport\x20React\x20from\x20\x22react\x22;\x0a\x0a//\x20bar.func.ts\x0aimport\x20{\x20getBaz\x20}\x20from\x20\x22bazFile.ts\x22;\x20//\x20bazFile\x20imports\x20React\x0a\x0a//\x20bar.func.ts\x0aimport\x20{\x20getFoo\x20}\x20from\x20\x22fooFile.ts\x22;\x20//\x20fooFile\x20imports\x20bazFile\x20that\x20imports\x20React\x0a\x0a####\x20Correct\x0a\x0a//\x20bar.func.ts\x0a//\x20doesn’t\x20import\x20React\x0aimport\x20{\x20getBaz\x20}\x20from\x20\x22bazFile.ts\x22;\x20//\x20bazFile\x20doesn’t\x20import\x20React\x0aimport\x20{\x20getFoo\x20}\x20from\x20\x22fooFile.ts\x22;\x20//\x20fooFile\x20doesn’t\x20import\x20bazFile\x20that\x20imports\x20React\x0a\x0a####\x20Why\x0a\x0aSeparates\x20component\x20dependencies,\x20avoids\x20cyclical\x20dependencies.'},'schema':[]}},createRule=ESLintUtils['RuleCreator'](_0x5caf9f=>''+url+_0x5caf9f),fileCache=new Map();function resolveFilePath(_0x819620,_0x4cd8fc){if(!_0x819620['startsWith']('.'))return void(0x8b1+0xe22+-0x16d3);const _0x5d20ba=_0x333991['resolve'](_0x4cd8fc,_0x819620),_0x184f92=['.ts','.tsx','.js','.jsx'],_0x1fc16d=[_0x5d20ba,..._0x184f92['map'](_0x21e04c=>_0x5d20ba+_0x21e04c),_0x333991['join'](_0x5d20ba,'index.ts'),_0x333991['join'](_0x5d20ba,'index.tsx'),_0x333991['join'](_0x5d20ba,'index.js'),_0x333991['join'](_0x5d20ba,'index.jsx')];return _0x1fc16d['find'](_0x434bb6=>_0x7f87ea['existsSync'](_0x434bb6))??void(0x1*0x1190+0x20e2+-0x1*0x3272);}__name(resolveFilePath,'resolveFilePath');function fileImportsReact(_0x507fbd,_0x5d7ec2=new Set()){let _0x4b4cd4=![];if(fileCache['has'](_0x507fbd))_0x4b4cd4=fileCache['get'](_0x507fbd)??![];else {if(!_0x5d7ec2['has'](_0x507fbd)&&_0x7f87ea['existsSync'](_0x507fbd)){_0x5d7ec2['add'](_0x507fbd);const _0x41017f=_0x7f87ea['readFileSync'](_0x507fbd,'utf8'),_0x58ce7c=/from\s+['"]react['"]/,_0x18812e=/import\s+[\s\S]{0,200}?from\s+['"]([^'"]{1,200})['"]/g;if(_0x58ce7c['test'](_0x41017f))_0x4b4cd4=!![];else for(const _0x31490f of _0x41017f['matchAll'](_0x18812e)){const _0x4cabcc=_0x31490f[0x214c+0x788+0x7*-0x5d5],_0x2bc207=resolveFilePath(_0x4cabcc,_0x333991['dirname'](_0x507fbd));if(_0x2bc207&&fileImportsReact(_0x2bc207,_0x5d7ec2)){_0x4b4cd4=!![];break;}}}}return fileCache['set'](_0x507fbd,_0x4b4cd4),_0x4b4cd4;}__name(fileImportsReact,'fileImportsReact');const mustNotImportReact=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0xcdd0a7){const _0x2d6548=_0xcdd0a7['filename'];if(!funcFileRegex['test'](_0x2d6548))return {};return {'ImportDeclaration'(_0x166767){const _0x31a7ec=_0x166767['source']['value'];if(typeof _0x31a7ec!=='string')return;if(forbiddenImports['includes'](_0x31a7ec['toLowerCase']())){_0xcdd0a7['report']({'node':_0x166767,'messageId':'mustNotImportReact'});return;}if(_0x31a7ec['startsWith']('.')){const _0x482281=resolveFilePath(_0x31a7ec,_0x333991['dirname'](_0x2d6548));_0x482281&&fileImportsReact(_0x482281)&&_0xcdd0a7['report']({'node':_0x166767,'messageId':'mustNotImportReact'});}}};}});
|
|
8
8
|
|
|
9
9
|
export { mustNotImportReact as default, ruleName };
|
|
@@ -3,6 +3,6 @@ import { ESLintUtils } from '@typescript-eslint/utils';
|
|
|
3
3
|
import { nodeTypes } from '@flint/infra/analysis';
|
|
4
4
|
import { url } from '@flint/infra/constants/rules-meta';
|
|
5
5
|
|
|
6
|
-
var __defProp=Object['defineProperty'],__name=(
|
|
6
|
+
var __defProp=Object['defineProperty'],__name=(_0x224a1d,_0x3b845f)=>__defProp(_0x224a1d,'name',{'value':_0x3b845f,'configurable':!![]});const ruleName='must-not-use-emojis';const constants={'emojiRegex':new RegExp('[\x5cp{Emoji_Presentation}\x5cp{Extended_Pictographic}][\x5cu{1F3FB}-\x5cu{1F3FF}]?[\x5cuFE0F\x5cuFE0E]?(?:\x5cu200D[\x5cp{Emoji_Presentation}\x5cp{Extended_Pictographic}][\x5cu{1F3FB}-\x5cu{1F3FF}]?[\x5cuFE0F\x5cuFE0E]?)*','gu'),'messageIds':{'mustNotUseEmojis':'mustNotUseEmojis'},'meta':{'type':'suggestion','docs':{'description':'Emoji\x20should\x20not\x20be\x20used.'},'messages':{'mustNotUseEmojis':'must-not-use-emojis\x0a###\x20**Must\x20not**\x20use\x20emojis.\x0a\x0a####\x20Wrong\x0a\x0aconsole.error(\x22✅\x20Error:\x22);\x0a\x0a####\x20Correct\x0a\x0aconsole.error(\x22Error:\x22);\x0a\x0a####\x20Why\x0a\x0aEmojis\x20may\x20not\x20be\x20supported\x20in\x20older\x20versions\x20of\x20consoles\x20or\x20logs.'},'schema':[],'fixable':'code'}},createRule=ESLintUtils['RuleCreator'](_0xe18ef4=>''+url+_0xe18ef4);function fixTemplateLiteralEmojis(_0xef2dcd,_0x44d786,_0x262912){const _0x1d8055=_0x262912['getText'](_0xef2dcd),_0x58cb26=_0x1d8055['replace'](constants['emojiRegex'],'');return _0x44d786['replaceText'](_0xef2dcd,_0x58cb26);}__name(fixTemplateLiteralEmojis,'fixTemplateLiteralEmojis');function fixLiteralEmojis(_0x27cf78,_0x24aa80){const _0x53eea4=_0x27cf78['value']['replace'](constants['emojiRegex'],''),_0x2cbc61=JSON['stringify'](_0x53eea4);return _0x24aa80['replaceText'](_0x27cf78,_0x2cbc61);}__name(fixLiteralEmojis,'fixLiteralEmojis');function fixCommentEmojis(_0x584b68,_0x5fb564){const _0x314ec2=_0x584b68['value']['replace'](constants['emojiRegex'],'');let _0x4068df;return _0x584b68['type']===nodeTypes['Line']?_0x4068df='//'+_0x314ec2:_0x4068df='/*'+_0x314ec2+'*/',_0x5fb564['replaceText'](_0x584b68,_0x4068df);}__name(fixCommentEmojis,'fixCommentEmojis');function hasEmoji(_0x39b005){return constants['emojiRegex']['lastIndex']=-0x2248+-0x22c8+0x4510,constants['emojiRegex']['test'](_0x39b005);}__name(hasEmoji,'hasEmoji');function hasEmojiInQuasis(_0x209340){return _0x209340['some'](_0x3d856b=>hasEmoji(_0x3d856b['value']['raw']));}__name(hasEmojiInQuasis,'hasEmojiInQuasis');const mustNotUseEmojis=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x2c752f){const _0x28b294=_0x2c752f['sourceCode'];return {[nodeTypes['literal']](_0x448705){typeof _0x448705['value']==='string'&&hasEmoji(_0x448705['value'])&&_0x2c752f['report']({'node':_0x448705,'messageId':constants['messageIds']['mustNotUseEmojis'],'fix'(_0x251ddd){return fixLiteralEmojis(_0x448705,_0x251ddd);}});},[nodeTypes['templateLiteral']](_0x1a0edd){if(!hasEmojiInQuasis(_0x1a0edd['quasis']))return;_0x2c752f['report']({'node':_0x1a0edd,'messageId':constants['messageIds']['mustNotUseEmojis'],'fix'(_0x23809a){return fixTemplateLiteralEmojis(_0x1a0edd,_0x23809a,_0x28b294);}});},[nodeTypes['program']](){const _0x556594=_0x28b294['getAllComments']();for(const _0x199e0f of _0x556594){hasEmoji(_0x199e0f['value'])&&_0x2c752f['report']({'loc':_0x199e0f['loc'],'messageId':constants['messageIds']['mustNotUseEmojis'],'fix'(_0x4d3c67){return fixCommentEmojis(_0x199e0f,_0x4d3c67);}});}}};}});
|
|
7
7
|
|
|
8
8
|
export { mustNotUseEmojis as default, ruleName };
|