@fernir2/saas-kit 0.0.203 → 0.0.204

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1371) hide show
  1. package/flint/index.d.ts +0 -1
  2. package/flint/index.js +0 -1
  3. package/generated/crud-handler-map.js +1 -1
  4. package/package.json +15 -10
  5. package/packages/base-repo/app-constants/aliases.js +1 -1
  6. package/packages/base-repo/app-constants/app-packages-names.d.ts +5 -0
  7. package/packages/base-repo/app-constants/app-packages-names.js +2 -2
  8. package/packages/base-repo/app-constants/command-names.d.ts +3 -0
  9. package/packages/base-repo/app-constants/command-names.js +2 -2
  10. package/packages/base-repo/app-constants/project-paths.d.ts +1 -1
  11. package/packages/base-repo/app-constants/project-paths.js +3 -2
  12. package/packages/base-repo/app-constants/system-constants.d.ts +2 -0
  13. package/packages/base-repo/app-constants/system-constants.js +2 -2
  14. package/packages/base-repo/constants/extensions.d.ts +2 -1
  15. package/packages/base-repo/constants/extensions.js +2 -2
  16. package/packages/base-repo/constants/http-methods.d.ts +3 -0
  17. package/packages/base-repo/constants/http-methods.js +1 -1
  18. package/packages/base-repo/constants/playwright.d.ts +7 -0
  19. package/packages/base-repo/constants/playwright.js +4 -0
  20. package/packages/base-repo/constants/string-duplication-constants.d.ts +3 -3
  21. package/packages/base-repo/constants/string-duplication-constants.js +1 -1
  22. package/packages/base-repo/constants/tools-constants.d.ts +22 -1
  23. package/packages/base-repo/constants/tools-constants.js +2 -2
  24. package/packages/base-repo/constants.d.ts +1 -1
  25. package/packages/base-repo/constants.js +2 -2
  26. package/packages/base-repo/tools/git/pre-commit-script.js +5 -5
  27. package/packages/cluster/contants/cluster-constants.d.ts +0 -1
  28. package/packages/cluster/contants/cluster-constants.js +1 -1
  29. package/packages/cluster/gitlab-runner.js +2 -2
  30. package/packages/cluster/networking.js +2 -2
  31. package/packages/cluster/postgres.js +3 -2
  32. package/packages/cluster/registry.js +2 -2
  33. package/packages/fd-toolbox/api/api-client.js +1 -1
  34. package/packages/fd-toolbox/api/api-path-names.js +2 -1
  35. package/packages/fd-toolbox/api/api-paths.js +2 -1
  36. package/packages/fd-toolbox/api/base-api.js +3 -2
  37. package/packages/fd-toolbox/api/cache-headers.js +1 -1
  38. package/packages/fd-toolbox/api/hooks/use-api.js +2 -2
  39. package/packages/fd-toolbox/auth/login-states.js +1 -1
  40. package/packages/fd-toolbox/auth/permissions/permission-notifiers.js +1 -1
  41. package/packages/fd-toolbox/auth/session-storage.js +1 -1
  42. package/packages/fd-toolbox/auth/tokens.js +1 -1
  43. package/packages/fd-toolbox/base-resource/base-resource.js +1 -1
  44. package/packages/fd-toolbox/base-resource/optional-user-id-base-resource.js +1 -1
  45. package/packages/fd-toolbox/base-resource/props/user-id-base-props-resource-props.js +2 -1
  46. package/packages/fd-toolbox/base-resource/props/with-optional-user-id-props.js +2 -1
  47. package/packages/fd-toolbox/base-resource/user-id-base-resource.js +1 -1
  48. package/packages/fd-toolbox/cache/cache.js +1 -1
  49. package/packages/fd-toolbox/collections/arrays.d.ts +1 -0
  50. package/packages/fd-toolbox/collections/arrays.js +2 -2
  51. package/packages/fd-toolbox/collections/enums.js +1 -1
  52. package/packages/fd-toolbox/constants/constants.d.ts +1 -0
  53. package/packages/fd-toolbox/constants/constants.js +2 -2
  54. package/packages/fd-toolbox/constants/element-suffixes.js +3 -1
  55. package/packages/fd-toolbox/constants/elements.js +3 -1
  56. package/packages/fd-toolbox/constants/environment-constants.d.ts +2 -1
  57. package/packages/fd-toolbox/constants/environment-constants.js +4 -1
  58. package/packages/fd-toolbox/constants/fd-resource-ids.js +2 -1
  59. package/packages/fd-toolbox/constants/file-constants.js +3 -1
  60. package/packages/fd-toolbox/constants/file-loader-data-types.js +1 -1
  61. package/packages/fd-toolbox/constants/header-names.d.ts +0 -1
  62. package/packages/fd-toolbox/constants/header-names.js +1 -1
  63. package/packages/fd-toolbox/constants/html-element-attributes.d.ts +1 -1
  64. package/packages/fd-toolbox/constants/html-element-attributes.js +3 -1
  65. package/packages/fd-toolbox/constants/keyboard-keys.js +3 -1
  66. package/packages/fd-toolbox/constants/odata-helper-constants.js +1 -1
  67. package/packages/fd-toolbox/constants/resource-folders.js +3 -1
  68. package/packages/fd-toolbox/constants/resource-id-constants.d.ts +1 -0
  69. package/packages/fd-toolbox/constants/resource-id-constants.js +1 -1
  70. package/packages/fd-toolbox/dates/date-formats.js +1 -1
  71. package/packages/fd-toolbox/dates/date-time.js +8 -8
  72. package/packages/fd-toolbox/enums/enums.js +1 -1
  73. package/packages/fd-toolbox/errors/error-handler.js +1 -1
  74. package/packages/fd-toolbox/errors/errors.js +1 -1
  75. package/packages/fd-toolbox/errors/problem-details.js +1 -1
  76. package/packages/fd-toolbox/functions/condition-check-functions.js +1 -1
  77. package/packages/fd-toolbox/functions/value-checking-functions.js +1 -1
  78. package/packages/fd-toolbox/hooks/use-async-effect.js +1 -1
  79. package/packages/fd-toolbox/hooks/use-element-id.js +1 -1
  80. package/packages/fd-toolbox/hooks/use-empty-ref.js +1 -1
  81. package/packages/fd-toolbox/hooks/use-enter-key.js +1 -1
  82. package/packages/fd-toolbox/hooks/use-is-client.js +1 -1
  83. package/packages/fd-toolbox/hooks/use-is-mobile.js +1 -1
  84. package/packages/fd-toolbox/hooks/use-keyboard-navigation.js +1 -1
  85. package/packages/fd-toolbox/hooks/use-media-query.js +1 -1
  86. package/packages/fd-toolbox/hooks/use-optional-promise.js +1 -1
  87. package/packages/fd-toolbox/html/element-ids.js +1 -1
  88. package/packages/fd-toolbox/html/extract-emails-from-html.js +1 -1
  89. package/packages/fd-toolbox/html/markdown-renderer.js +1 -1
  90. package/packages/fd-toolbox/http/http.js +1 -1
  91. package/packages/fd-toolbox/http/url/url-builder.js +1 -1
  92. package/packages/fd-toolbox/http/url/urls.js +1 -1
  93. package/packages/fd-toolbox/infra/env-config.js +2 -2
  94. package/packages/fd-toolbox/infra/env-functions.js +2 -2
  95. package/packages/fd-toolbox/infra/env-schema.d.ts +6 -6
  96. package/packages/fd-toolbox/infra/env-schema.js +6 -3
  97. package/packages/fd-toolbox/infra/env-store.js +1 -1
  98. package/packages/fd-toolbox/infra/toolbox-env-setting-keys.d.ts +3 -0
  99. package/packages/fd-toolbox/infra/toolbox-env-setting-keys.js +1 -1
  100. package/packages/fd-toolbox/io/io.js +1 -1
  101. package/packages/fd-toolbox/lib/environments.d.ts +1 -1
  102. package/packages/fd-toolbox/lib/environments.js +1 -1
  103. package/packages/fd-toolbox/lib/utils.js +2 -1
  104. package/packages/fd-toolbox/local-storage/local-storage.js +1 -1
  105. package/packages/fd-toolbox/logging/cli-logger.js +3 -1
  106. package/packages/fd-toolbox/logging/loggers.d.ts +1 -1
  107. package/packages/fd-toolbox/logging/loggers.js +1 -1
  108. package/packages/fd-toolbox/notifications.js +2 -2
  109. package/packages/fd-toolbox/numbers/numbers.js +1 -1
  110. package/packages/fd-toolbox/objects/property-value.js +1 -1
  111. package/packages/fd-toolbox/odata/odata-builder-funcs.js +1 -1
  112. package/packages/fd-toolbox/odata/odata-builders.js +1 -1
  113. package/packages/fd-toolbox/odata/odata-constants.js +1 -1
  114. package/packages/fd-toolbox/odata/odata.js +4 -1
  115. package/packages/fd-toolbox/odata/odataconfig.js +1 -1
  116. package/packages/fd-toolbox/odata/services/odata-filters.js +1 -1
  117. package/packages/fd-toolbox/odata/services/odata-parsers.js +1 -1
  118. package/packages/fd-toolbox/path.js +1 -1
  119. package/packages/fd-toolbox/paths/ensure.js +1 -1
  120. package/packages/fd-toolbox/paths/paths-names.js +1 -1
  121. package/packages/fd-toolbox/permissions/constants/crud-action-to-permission-prefix.js +2 -1
  122. package/packages/fd-toolbox/property/calculate-total-property-value.js +1 -1
  123. package/packages/fd-toolbox/redirect/redirect-functions.js +1 -1
  124. package/packages/fd-toolbox/routing/login-routers.js +1 -1
  125. package/packages/fd-toolbox/routing/paths.js +1 -1
  126. package/packages/fd-toolbox/routing/public-routes.js +1 -1
  127. package/packages/fd-toolbox/routing/routers.js +2 -1
  128. package/packages/fd-toolbox/routing/routes.js +1 -1
  129. package/packages/fd-toolbox/server/api/query-params.js +3 -1
  130. package/packages/fd-toolbox/server/auth/cookies.js +1 -1
  131. package/packages/fd-toolbox/server/cachings/core-cache.js +1 -1
  132. package/packages/fd-toolbox/server/cachings/fd-memory-cache.js +1 -1
  133. package/packages/fd-toolbox/server/cachings/fd-remote-cache.js +2 -2
  134. package/packages/fd-toolbox/server/collections/single-funcs.js +1 -1
  135. package/packages/fd-toolbox/server/configs/configs.js +2 -1
  136. package/packages/fd-toolbox/server/constants/crud-actions-constants.js +3 -1
  137. package/packages/fd-toolbox/server/constants/fd-server-cache-keys.js +3 -1
  138. package/packages/fd-toolbox/server/entities/base-objects.js +1 -1
  139. package/packages/fd-toolbox/server/errors/error-dtos.js +1 -1
  140. package/packages/fd-toolbox/server/framework/index.js +1 -1
  141. package/packages/fd-toolbox/server/logging/latest-logs-store.js +1 -1
  142. package/packages/fd-toolbox/server/logging/log-dtos.js +1 -1
  143. package/packages/fd-toolbox/server/logging/logger.js +1 -1
  144. package/packages/fd-toolbox/server/objects/keys-case-converters.js +1 -1
  145. package/packages/fd-toolbox/server/random.js +1 -1
  146. package/packages/fd-toolbox/server/services/dictionaries.js +1 -1
  147. package/packages/fd-toolbox/server/strings/casing.js +1 -1
  148. package/packages/fd-toolbox/server/strings/strings.js +3 -1
  149. package/packages/fd-toolbox/server/time/duration-service.js +1 -1
  150. package/packages/fd-toolbox/server/web/errors.js +1 -1
  151. package/packages/fd-toolbox/state/component-states.js +1 -1
  152. package/packages/fd-toolbox/strings/case-converters.js +1 -1
  153. package/packages/fd-toolbox/strings/casing-converter.js +1 -1
  154. package/packages/fd-toolbox/strings/plural-converters.js +3 -1
  155. package/packages/fd-toolbox/strings/strings-constants.d.ts +6 -1
  156. package/packages/fd-toolbox/strings/strings-constants.js +2 -2
  157. package/packages/fd-toolbox/strings/strings.js +2 -2
  158. package/packages/fd-toolbox/time/date-time.js +1 -1
  159. package/packages/fd-toolbox/types/crud/crud-results.js +1 -1
  160. package/packages/fd-toolbox/types/ensure-type.js +3 -1
  161. package/packages/fd-toolbox/types/react-types.d.ts +1 -2
  162. package/packages/fd-toolbox/types/with-user-id.js +2 -1
  163. package/packages/fd-toolbox/url/urls.js +1 -1
  164. package/packages/fd-toolbox/uuids.d.ts +0 -1
  165. package/packages/fd-toolbox/uuids.js +3 -2
  166. package/packages/fd-toolbox/value-checkers.js +1 -1
  167. package/packages/fd-toolbox-core/constants/base-dev-url.js +1 -1
  168. package/packages/fd-toolbox-core/core/name-of.js +1 -1
  169. package/packages/fd-toolbox-core/types/resource-with-id.js +1 -1
  170. package/packages/flint/dist/rules/index.d.ts +9 -1
  171. package/packages/flint/dist/rules/index.js +10 -9
  172. package/packages/flint/eslint-base.config.js +13 -13
  173. package/packages/flint/eslint-next-web-vitals-temp.config.js +2 -2
  174. package/packages/flint/infra/analysis/array-analysis.js +8 -0
  175. package/packages/flint/infra/analysis/casing-analysis.js +4 -0
  176. package/packages/flint/infra/analysis/enum-analysis.js +12 -0
  177. package/packages/flint/infra/analysis/eslint-analysis.js +6 -0
  178. package/packages/flint/infra/analysis/expression-analysis.js +7 -0
  179. package/packages/flint/infra/analysis/formatting-analysis.js +6 -0
  180. package/packages/flint/infra/{ast-helpers → analysis}/function-analysis.d.ts +1 -0
  181. package/packages/flint/infra/analysis/function-analysis.js +8 -0
  182. package/packages/flint/infra/analysis/jsx-analysis.js +8 -0
  183. package/packages/flint/infra/analysis/module-analysis.js +11 -0
  184. package/packages/flint/infra/{ast-helpers → analysis}/name-analysis.d.ts +1 -1
  185. package/packages/flint/infra/analysis/name-analysis.js +10 -0
  186. package/packages/flint/infra/analysis/nullish-analysis.js +7 -0
  187. package/packages/flint/infra/analysis/number-analysis.js +8 -0
  188. package/packages/flint/infra/{ast-helpers → analysis}/object-analysis.d.ts +1 -1
  189. package/packages/flint/infra/analysis/object-analysis.js +6 -0
  190. package/packages/flint/infra/analysis/return-analysis.d.ts +6 -0
  191. package/packages/flint/infra/analysis/return-analysis.js +7 -0
  192. package/packages/flint/infra/analysis/scope-analysis.js +11 -0
  193. package/packages/flint/infra/analysis/string-analysis.js +10 -0
  194. package/packages/flint/infra/analysis/tree-analysis.js +6 -0
  195. package/packages/flint/infra/{ast-helpers → analysis}/type-analysis.d.ts +17 -1
  196. package/packages/flint/infra/analysis/type-analysis.js +9 -0
  197. package/packages/flint/infra/{ast-helpers → analysis}/type-guards.d.ts +10 -4
  198. package/packages/flint/infra/analysis/type-guards.js +12 -0
  199. package/packages/flint/infra/analysis/variable-analysis.d.ts +4 -0
  200. package/packages/flint/infra/analysis/variable-analysis.js +8 -0
  201. package/packages/flint/infra/{ast-helpers → analysis}/visitors.d.ts +2 -1
  202. package/packages/flint/infra/analysis/visitors.js +6 -0
  203. package/packages/flint/infra/config-edited-checker.d.ts +2 -0
  204. package/packages/flint/infra/config-edited-checker.js +7 -0
  205. package/packages/flint/infra/constants/rules-meta.d.ts +6 -0
  206. package/packages/flint/infra/constants/rules-meta.js +2 -2
  207. package/packages/flint/infra/create-eslint-rule.js +7 -0
  208. package/packages/flint/infra/git-readers.d.ts +1 -0
  209. package/packages/flint/infra/git-readers.js +10 -0
  210. package/packages/flint/non-level-two-eslint-config.js +1 -1
  211. package/packages/flint/project-specific-eslint-configs.js +7 -7
  212. package/packages/flint/rules/code-duplication/must-avoid-code-duplication-in-functions.d.ts +1 -0
  213. package/packages/flint/rules/code-duplication/must-avoid-code-duplication-in-functions.js +4 -3
  214. package/packages/flint/rules/code-duplication/no-duplicate-imports.d.ts +1 -0
  215. package/packages/flint/rules/code-duplication/no-duplicate-imports.js +4 -3
  216. package/packages/flint/rules/code-duplication/no-literal-duplication.js +3 -3
  217. package/packages/flint/rules/consistency/enum-type-immediate-definition.js +3 -3
  218. package/packages/flint/rules/consistency/must-not-needlessly-copy-arrays.js +3 -3
  219. package/packages/flint/rules/consistency/must-not-use-anonymous-objects-only-with-explicit-typization.js +3 -3
  220. package/packages/flint/rules/consistency/must-not-use-process-env.js +3 -3
  221. package/packages/flint/rules/consistency/must-use-nameof-for-props.d.ts +1 -0
  222. package/packages/flint/rules/consistency/must-use-nameof-for-props.js +4 -3
  223. package/packages/flint/rules/consistency/must-use-typed-resources-for-crud-update.d.ts +3 -0
  224. package/packages/flint/rules/consistency/must-use-typed-resources-for-crud-update.js +9 -0
  225. package/packages/flint/rules/consistency/must-use-typescript.js +3 -3
  226. package/packages/flint/rules/consistency/no-index-import-in-ast-helpers.d.ts +3 -0
  227. package/packages/flint/rules/consistency/no-index-import-in-ast-helpers.js +6 -0
  228. package/packages/flint/rules/consistency/no-new-date.d.ts +1 -0
  229. package/packages/flint/rules/consistency/no-new-date.js +4 -3
  230. package/packages/flint/rules/consistency/no-redundant-type-alias.d.ts +1 -0
  231. package/packages/flint/rules/consistency/no-redundant-type-alias.js +4 -3
  232. package/packages/flint/rules/consistency/no-use-type-undefined-for-optional.d.ts +1 -0
  233. package/packages/flint/rules/consistency/no-use-type-undefined-for-optional.js +4 -3
  234. package/packages/flint/rules/css/must-not-use-important.js +2 -2
  235. package/packages/flint/rules/css/no-array-destructuring-from-function-calls.d.ts +1 -0
  236. package/packages/flint/rules/css/no-array-destructuring-from-function-calls.js +4 -3
  237. package/packages/flint/rules/css/no-px-in-tailwind.js +2 -2
  238. package/packages/flint/rules/css/no-tailwind-colors.d.ts +1 -0
  239. package/packages/flint/rules/css/no-tailwind-colors.js +4 -3
  240. package/packages/flint/rules/flint/must-add-custom-rule-in-config.d.ts +1 -0
  241. package/packages/flint/rules/flint/must-add-custom-rule-in-config.js +8 -5
  242. package/packages/flint/rules/flint/must-have-both-rule-and-tests.d.ts +1 -0
  243. package/packages/flint/rules/flint/must-have-both-rule-and-tests.js +5 -4
  244. package/packages/flint/rules/flint/must-match-rule-name-with-file-name.js +4 -4
  245. package/packages/flint/rules/flint/must-not-declare-fixer-without-calling-it.js +2 -2
  246. package/packages/flint/rules/flint/must-not-import-ast-node-types.js +3 -3
  247. package/packages/flint/rules/flint/must-not-use-eslint-deprecated-methods.js +2 -2
  248. package/packages/flint/rules/flint/must-use-better-error-message-for-custom-rules.d.ts +14 -0
  249. package/packages/flint/rules/flint/must-use-better-error-message-for-custom-rules.js +4 -4
  250. package/packages/flint/rules/flint/must-use-constants-for-message-ids.js +3 -4
  251. package/packages/flint/rules/flint/must-use-create-eslint-rule.js +3 -3
  252. package/packages/flint/rules/flint/must-use-link-for-camel-or-pascal-case-names.d.ts +1 -0
  253. package/packages/flint/rules/flint/must-use-link-for-camel-or-pascal-case-names.js +6 -5
  254. package/packages/flint/rules/flint/must-use-nodetypes-structure-instead-of-string-node-type.d.ts +4 -0
  255. package/packages/flint/rules/flint/must-use-nodetypes-structure-instead-of-string-node-type.js +8 -0
  256. package/packages/flint/rules/flint/must-use-unique-filenames-with-comment-in-tests.js +2 -2
  257. package/packages/flint/rules/general/group-consts-as-const.js +3 -3
  258. package/packages/flint/rules/general/must-add-space-for-comments.d.ts +1 -0
  259. package/packages/flint/rules/general/must-add-space-for-comments.js +3 -2
  260. package/packages/flint/rules/general/must-create-resources-in-src-dir.d.ts +1 -0
  261. package/packages/flint/rules/general/must-create-resources-in-src-dir.js +3 -2
  262. package/packages/flint/rules/general/must-not-define-functions-in-constants-files.js +3 -3
  263. package/packages/flint/rules/general/must-not-pass-full-objects-into-functions-needlessly.d.ts +1 -0
  264. package/packages/flint/rules/general/must-not-pass-full-objects-into-functions-needlessly.js +5 -4
  265. package/packages/flint/rules/general/must-start-comments-with-uppercase.d.ts +1 -0
  266. package/packages/flint/rules/general/must-start-comments-with-uppercase.js +3 -2
  267. package/packages/flint/rules/general/must-use-native-private.d.ts +1 -0
  268. package/packages/flint/rules/general/must-use-native-private.js +4 -3
  269. package/packages/flint/rules/general/must-use-strict-dependency-version.d.ts +1 -0
  270. package/packages/flint/rules/general/must-use-strict-dependency-version.js +3 -2
  271. package/packages/flint/rules/general/no-empty-files.d.ts +1 -0
  272. package/packages/flint/rules/general/no-empty-files.js +4 -3
  273. package/packages/flint/rules/general/no-eslint-disable-without-approved.d.ts +1 -0
  274. package/packages/flint/rules/general/no-eslint-disable-without-approved.js +4 -4
  275. package/packages/flint/rules/general/no-import-from-temp-dev.d.ts +1 -0
  276. package/packages/flint/rules/general/no-import-from-temp-dev.js +4 -3
  277. package/packages/flint/rules/general/no-specify-return-type.d.ts +1 -0
  278. package/packages/flint/rules/general/no-specify-return-type.js +4 -3
  279. package/packages/flint/rules/general/no-todo.d.ts +1 -0
  280. package/packages/flint/rules/general/no-todo.js +3 -2
  281. package/packages/flint/rules/general/use-of-only-english-in-repository.d.ts +1 -0
  282. package/packages/flint/rules/general/use-of-only-english-in-repository.js +4 -3
  283. package/packages/flint/rules/index.js +138 -130
  284. package/packages/flint/rules/must-always-specify-types-for-api-responses.d.ts +3 -0
  285. package/packages/flint/rules/must-always-specify-types-for-api-responses.js +7 -0
  286. package/packages/flint/rules/must-declare-module-members-in-consistent-order.js +3 -3
  287. package/packages/flint/rules/must-not-modify-data-or-workspace-in-readonly-tests.js +3 -3
  288. package/packages/flint/rules/must-not-return-empty-strings.js +3 -3
  289. package/packages/flint/rules/must-not-use-all-caps-constants.js +3 -3
  290. package/packages/flint/rules/must-not-use-fetch.js +3 -3
  291. package/packages/flint/rules/must-not-use-inline-object-type-parameters.js +2 -2
  292. package/packages/flint/rules/must-not-use-placeholders-in-eslint-rule-titles.js +3 -3
  293. package/packages/flint/rules/must-not-use-see-link-in-docs-if-type-available.js +3 -4
  294. package/packages/flint/rules/must-separate-unrelated-tests-into-different-files.js +3 -3
  295. package/packages/flint/rules/must-specify-second-generic-parameter-in-apipost-and-apiput.d.ts +4 -0
  296. package/packages/flint/rules/must-specify-second-generic-parameter-in-apipost-and-apiput.js +7 -0
  297. package/packages/flint/rules/must-use-color-variables-instead-of-hardcoded-values.js +3 -3
  298. package/packages/flint/rules/must-use-functions-for-component-ids.js +3 -3
  299. package/packages/flint/rules/must-use-odata-builder.d.ts +3 -0
  300. package/packages/flint/rules/must-use-odata-builder.js +7 -0
  301. package/packages/flint/rules/must-use-only-crud-operations.js +3 -3
  302. package/packages/flint/rules/naming/filename-kebab-case.d.ts +1 -0
  303. package/packages/flint/rules/naming/filename-kebab-case.js +4 -3
  304. package/packages/flint/rules/naming/must-add-empty-line-before-assert-act-arrange.js +1 -1
  305. package/packages/flint/rules/naming/must-add-prefix-to-po-functions.d.ts +1 -0
  306. package/packages/flint/rules/naming/must-add-prefix-to-po-functions.js +4 -3
  307. package/packages/flint/rules/naming/must-avoid-non-null-assertions.js +2 -2
  308. package/packages/flint/rules/naming/must-create-assert-functions-in-asserts-files.d.ts +1 -0
  309. package/packages/flint/rules/naming/must-create-assert-functions-in-asserts-files.js +4 -3
  310. package/packages/flint/rules/naming/must-get-elements-in-tests-only-by-id.d.ts +1 -0
  311. package/packages/flint/rules/naming/must-get-elements-in-tests-only-by-id.js +4 -3
  312. package/packages/flint/rules/naming/must-name-ui-tests-component-condition-expected-result.d.ts +1 -0
  313. package/packages/flint/rules/naming/must-name-ui-tests-component-condition-expected-result.js +4 -3
  314. package/packages/flint/rules/naming/must-not-add-files-and-code-in-lib-folder.d.ts +1 -0
  315. package/packages/flint/rules/naming/must-not-add-files-and-code-in-lib-folder.js +4 -3
  316. package/packages/flint/rules/naming/must-not-create-funcs-files-for-non-components.js +3 -3
  317. package/packages/flint/rules/naming/must-not-declare-func-inside-another-func.d.ts +1 -0
  318. package/packages/flint/rules/naming/must-not-declare-func-inside-another-func.js +4 -3
  319. package/packages/flint/rules/naming/must-not-import-react.d.ts +1 -0
  320. package/packages/flint/rules/naming/must-not-import-react.js +5 -4
  321. package/packages/flint/rules/naming/must-not-use-emojis.d.ts +1 -0
  322. package/packages/flint/rules/naming/must-not-use-emojis.js +4 -3
  323. package/packages/flint/rules/naming/must-not-use-indexed-access-type-in-function-params.js +3 -3
  324. package/packages/flint/rules/naming/must-not-use-location-href.d.ts +1 -0
  325. package/packages/flint/rules/naming/must-not-use-location-href.js +4 -3
  326. package/packages/flint/rules/naming/must-not-use-negation-with-enums.d.ts +1 -0
  327. package/packages/flint/rules/naming/must-not-use-negation-with-enums.js +4 -3
  328. package/packages/flint/rules/naming/must-not-use-null.d.ts +1 -0
  329. package/packages/flint/rules/naming/must-not-use-null.js +4 -3
  330. package/packages/flint/rules/naming/must-not-use-po-in-assert-functions.d.ts +1 -0
  331. package/packages/flint/rules/naming/must-not-use-po-in-assert-functions.js +4 -3
  332. package/packages/flint/rules/naming/must-not-use-redundant-string.d.ts +1 -0
  333. package/packages/flint/rules/naming/must-not-use-redundant-string.js +4 -3
  334. package/packages/flint/rules/naming/must-not-use-ternary-operator-for-complicated-conditions.d.ts +1 -0
  335. package/packages/flint/rules/naming/must-not-use-ternary-operator-for-complicated-conditions.js +4 -3
  336. package/packages/flint/rules/naming/must-put-empty-line.d.ts +1 -0
  337. package/packages/flint/rules/naming/must-put-empty-line.js +4 -3
  338. package/packages/flint/rules/naming/must-throw-full-error-objects.js +2 -2
  339. package/packages/flint/rules/naming/must-use-camelcase-for-html-items-id-attribute.d.ts +1 -0
  340. package/packages/flint/rules/naming/must-use-camelcase-for-html-items-id-attribute.js +4 -4
  341. package/packages/flint/rules/naming/must-use-descriptive-names-for-functions-and-parameters.js +3 -3
  342. package/packages/flint/rules/naming/must-use-env-keys-from-constant.js +3 -3
  343. package/packages/flint/rules/naming/must-use-example-domain.d.ts +1 -0
  344. package/packages/flint/rules/naming/must-use-example-domain.js +4 -3
  345. package/packages/flint/rules/naming/must-use-filename-in-assert-functions.d.ts +1 -0
  346. package/packages/flint/rules/naming/must-use-filename-in-assert-functions.js +4 -3
  347. package/packages/flint/rules/naming/must-use-func-declaration-for-named-func.d.ts +1 -0
  348. package/packages/flint/rules/naming/must-use-func-declaration-for-named-func.js +4 -3
  349. package/packages/flint/rules/naming/must-use-function-for-component.d.ts +1 -0
  350. package/packages/flint/rules/naming/must-use-function-for-component.js +4 -3
  351. package/packages/flint/rules/naming/must-use-interface-for-props.d.ts +1 -0
  352. package/packages/flint/rules/naming/must-use-interface-for-props.js +4 -3
  353. package/packages/flint/rules/naming/must-use-new-url-constructor.d.ts +1 -0
  354. package/packages/flint/rules/naming/must-use-new-url-constructor.js +5 -3
  355. package/packages/flint/rules/naming/must-use-pascal-case-for-types-and-interfaces.d.ts +1 -0
  356. package/packages/flint/rules/naming/must-use-pascal-case-for-types-and-interfaces.js +4 -3
  357. package/packages/flint/rules/naming/must-use-plural-enum-const-and-singular-type.d.ts +1 -0
  358. package/packages/flint/rules/naming/must-use-plural-enum-const-and-singular-type.js +5 -4
  359. package/packages/flint/rules/naming/must-use-plural-in-function-names-if-returns-array.d.ts +1 -0
  360. package/packages/flint/rules/naming/must-use-plural-in-function-names-if-returns-array.js +6 -5
  361. package/packages/flint/rules/naming/must-use-plural-names-of-files-for-arrays.js +5 -5
  362. package/packages/flint/rules/naming/must-use-resource-name-instead-of-resource.d.ts +3 -0
  363. package/packages/flint/rules/naming/must-use-resource-name-instead-of-resource.js +7 -0
  364. package/packages/flint/rules/naming/must-use-s-ending-for-natural-plurals.d.ts +1 -0
  365. package/packages/flint/rules/naming/must-use-s-ending-for-natural-plurals.js +5 -4
  366. package/packages/flint/rules/naming/must-use-the-fd-prefix-for-env-variables.js +2 -2
  367. package/packages/flint/rules/naming/must-use-wrappers-to-access-first-element.d.ts +3 -0
  368. package/packages/flint/rules/naming/must-use-wrappers-to-access-first-element.js +7 -0
  369. package/packages/flint/rules/naming/no-conflicting-props.d.ts +1 -0
  370. package/packages/flint/rules/naming/no-conflicting-props.js +4 -3
  371. package/packages/flint/rules/naming/no-default-props.d.ts +1 -0
  372. package/packages/flint/rules/naming/no-default-props.js +4 -3
  373. package/packages/flint/rules/naming/no-delays-in-ui-tests.d.ts +1 -0
  374. package/packages/flint/rules/naming/no-delays-in-ui-tests.js +4 -3
  375. package/packages/flint/rules/naming/no-fd-prefix-in-folders.d.ts +1 -0
  376. package/packages/flint/rules/naming/no-fd-prefix-in-folders.js +4 -3
  377. package/packages/flint/rules/naming/no-get-in-function-names-without-return.d.ts +6 -0
  378. package/packages/flint/rules/naming/no-get-in-function-names-without-return.js +4 -3
  379. package/packages/flint/rules/naming/no-integers-instead-of-enums.d.ts +1 -0
  380. package/packages/flint/rules/naming/no-integers-instead-of-enums.js +5 -4
  381. package/packages/flint/rules/naming/no-nullable-check.d.ts +1 -0
  382. package/packages/flint/rules/naming/no-nullable-check.js +4 -3
  383. package/packages/flint/rules/naming/no-untyped-objects-between-components.d.ts +1 -0
  384. package/packages/flint/rules/naming/no-untyped-objects-between-components.js +5 -4
  385. package/packages/flint/rules/naming/no-use-conditional-logic-in-test-assertions.d.ts +1 -0
  386. package/packages/flint/rules/naming/no-use-conditional-logic-in-test-assertions.js +4 -3
  387. package/packages/flint/rules/naming/no-use-enum.d.ts +1 -0
  388. package/packages/flint/rules/naming/no-use-enum.js +3 -2
  389. package/packages/flint/rules/naming/no-use-id.d.ts +1 -0
  390. package/packages/flint/rules/naming/no-use-id.js +4 -3
  391. package/packages/flint/rules/naming/no-utils-helpers-naming.d.ts +3 -0
  392. package/packages/flint/rules/naming/no-utils-helpers-naming.js +7 -0
  393. package/packages/flint/rules/naming/use-on-prefix.d.ts +1 -0
  394. package/packages/flint/rules/naming/use-on-prefix.js +4 -3
  395. package/packages/flint/rules/performance/must-clean-up-event-listeners.d.ts +1 -0
  396. package/packages/flint/rules/performance/must-clean-up-event-listeners.js +4 -3
  397. package/packages/flint/rules/readability/component-function-max-lines.js +3 -3
  398. package/packages/flint/rules/readability/exported-func-above-regular.js +3 -3
  399. package/packages/flint/rules/readability/for-each-max-lines.d.ts +1 -0
  400. package/packages/flint/rules/readability/for-each-max-lines.js +4 -3
  401. package/packages/flint/rules/readability/max-lines-per-function.d.ts +1 -0
  402. package/packages/flint/rules/readability/max-lines-per-function.js +4 -3
  403. package/packages/flint/rules/readability/must-consolidate-conditional-expressions.d.ts +1 -0
  404. package/packages/flint/rules/readability/must-consolidate-conditional-expressions.js +4 -3
  405. package/packages/flint/rules/readability/must-do-await-data-in-one-line.js +2 -2
  406. package/packages/flint/rules/readability/must-limit-lines-without-comments.d.ts +1 -0
  407. package/packages/flint/rules/readability/must-limit-lines-without-comments.js +3 -2
  408. package/packages/flint/rules/readability/must-not-destructure-function-parameters.js +3 -3
  409. package/packages/flint/rules/readability/must-not-use-empty-lines-in-html.js +3 -3
  410. package/packages/flint/rules/readability/must-not-use-inline-await.js +3 -3
  411. package/packages/flint/rules/readability/must-return-empty-array.d.ts +3 -0
  412. package/packages/flint/rules/readability/must-return-empty-array.js +7 -0
  413. package/packages/flint/rules/readability/must-use-alt-to-describe-images.d.ts +1 -0
  414. package/packages/flint/rules/readability/must-use-alt-to-describe-images.js +4 -4
  415. package/packages/flint/rules/readability/must-use-create-error.d.ts +1 -0
  416. package/packages/flint/rules/readability/must-use-create-error.js +4 -3
  417. package/packages/flint/rules/readability/must-use-interfaces-for-complex-types.d.ts +1 -0
  418. package/packages/flint/rules/readability/must-use-interfaces-for-complex-types.js +4 -3
  419. package/packages/flint/rules/readability/must-use-single-return-in-function.js +3 -3
  420. package/packages/flint/rules/readability/must-use-test-comments.d.ts +1 -0
  421. package/packages/flint/rules/readability/must-use-test-comments.js +4 -3
  422. package/packages/flint/rules/readability/no-centralized-error-messages.js +2 -2
  423. package/packages/flint/rules/readability/no-constructor-name-for-resource.d.ts +1 -0
  424. package/packages/flint/rules/readability/no-constructor-name-for-resource.js +4 -3
  425. package/packages/flint/rules/readability/no-long-filter-map.d.ts +1 -0
  426. package/packages/flint/rules/readability/no-long-filter-map.js +4 -3
  427. package/packages/flint/rules/readability/no-naked-query-return.js +3 -3
  428. package/packages/flint/rules/readability/no-string-length-check.d.ts +1 -0
  429. package/packages/flint/rules/readability/no-string-length-check.js +4 -3
  430. package/packages/flint/rules/readability/no-then.d.ts +1 -0
  431. package/packages/flint/rules/readability/no-then.js +4 -3
  432. package/packages/flint/rules/readability/no-to-lower-case-with-resource-name.js +3 -3
  433. package/packages/flint/rules/readability/no-useless-destructing.js +3 -3
  434. package/packages/flint/rules/readability/use-function-without-parameter-shortcut.js +3 -3
  435. package/packages/flint/rules/readability/use-nullish-coalescing-for-default.d.ts +1 -0
  436. package/packages/flint/rules/readability/use-nullish-coalescing-for-default.js +5 -4
  437. package/packages/infra/ci/constants/ci-constants.js +1 -1
  438. package/packages/infra/ci/constants/git-commands.d.ts +0 -5
  439. package/packages/infra/ci/constants/git-commands.js +2 -2
  440. package/packages/infra/ci/constants/npm-commands.d.ts +1 -1
  441. package/packages/infra/ci/constants/npm-commands.js +1 -1
  442. package/packages/infra/ci/jobs/build-and-test.js +1 -2
  443. package/packages/infra/ci/jobs/build-db-connection-string.js +1 -1
  444. package/packages/infra/ci/jobs/build-package.js +1 -1
  445. package/packages/infra/ci/jobs/ci-auto-merge.js +1 -1
  446. package/packages/infra/ci/jobs/clear-nx-cache.js +1 -1
  447. package/packages/infra/ci/jobs/cli-create-test.js +2 -2
  448. package/packages/infra/ci/jobs/deploy-to-vercel.js +2 -2
  449. package/packages/infra/ci/jobs/drop-all-db.js +2 -2
  450. package/packages/infra/ci/jobs/lint.js +3 -2
  451. package/packages/infra/ci/jobs/manual-cleanup.js +1 -1
  452. package/packages/infra/ci/jobs/publish-package.js +1 -1
  453. package/packages/infra/ci/jobs/ranksters-build-and-test.js +1 -1
  454. package/packages/infra/ci/jobs/saas-kit-test-build-and-test.js +2 -2
  455. package/packages/infra/ci/jobs/sync-saas-kit-version-to-main.js +2 -2
  456. package/packages/infra/ci/jobs/unpublish-package.js +2 -2
  457. package/packages/infra/ci/jobs/update-submodules.js +2 -2
  458. package/packages/infra/ci/setup/checkout-and-sync-submodules.js +2 -2
  459. package/packages/infra/ci/setup/cleanup.js +2 -2
  460. package/packages/infra/ci/setup/clear-nx-cache-environment.js +1 -1
  461. package/packages/infra/ci/setup/copy-playwright-report.js +3 -3
  462. package/packages/infra/ci/setup/get-build-package-info.js +1 -1
  463. package/packages/infra/ci/setup/get-latest-npm-package-info.js +1 -1
  464. package/packages/infra/ci/setup/init-db.js +1 -1
  465. package/packages/infra/ci/setup/install-local-saaskit.js +3 -3
  466. package/packages/infra/ci/setup/npm-auth.js +2 -2
  467. package/packages/infra/ci/setup/prepare-environment.js +2 -2
  468. package/packages/infra/ci/setup/prettier.js +2 -2
  469. package/packages/infra/ci/setup/resolve-and-checkout-submodule-branch.js +2 -2
  470. package/packages/infra/ci/setup/resolve-main-repo-branch.js +2 -2
  471. package/packages/infra/ci/setup/rollup-cache-cloud.js +2 -2
  472. package/packages/infra/ci/setup/setup-submodules.js +2 -2
  473. package/packages/infra/ci/setup/spawn-background-server.js +1 -1
  474. package/packages/infra/ci/setup/sync-build-artifacts.js +1 -1
  475. package/packages/infra/ci/setup/update-workspace-dependencies.js +1 -1
  476. package/packages/infra/ci/setup/verify-published-version.js +1 -1
  477. package/packages/infra/ci/utils/cloud-client.js +1 -1
  478. package/packages/infra/ci/utils/create-early-infra-error.js +1 -1
  479. package/packages/infra/ci/utils/exec.js +1 -1
  480. package/packages/infra/ci/utils/git-command-funcs.js +1 -1
  481. package/packages/infra/ci/utils/git.js +5 -5
  482. package/packages/infra/ci/utils/npm-command-funcs.js +2 -2
  483. package/packages/infra/deploy/cluster/cluster-deploy-setup.js +1 -1
  484. package/packages/infra/git/gitlab/gitlab.js +1 -1
  485. package/packages/infra/plugins/dirname-plugin.js +1 -1
  486. package/packages/level2/ai/server/ai-deepinfra.js +1 -1
  487. package/packages/level2/ai/server/ai-google.js +1 -1
  488. package/packages/level2/ai/server/ai-groq.js +1 -1
  489. package/packages/level2/ai/vercel-ai-sdk/ai.js +1 -1
  490. package/packages/level2/cli/create/configs/drizzle-cli-config.js +2 -1
  491. package/packages/level2/cli/create/configs/next-cli-config.d.ts +11 -31
  492. package/packages/level2/cli/create/configs/next-cli-config.js +1 -3
  493. package/packages/level2/cli/create/configs/playwright-cli-config.js +4 -1
  494. package/packages/level2/client/component-configs/configure-default-config.js +1 -1
  495. package/packages/level2/client/component-configs/edit-resource-configs.js +1 -1
  496. package/packages/level2/client/component-configs/multi-list-config.js +1 -1
  497. package/packages/level2/client/component-configs/resource-list-configs.js +1 -1
  498. package/packages/level2/client/component-configs/workspace-settings-config.js +1 -1
  499. package/packages/level2/client/components/subscription-plan/SubscriptionPlan.funcs.js +1 -1
  500. package/packages/level2/client/components/subscription-plan/SubscriptionPlan.js +2 -5
  501. package/packages/level2/client/components/subscription-plan/subscription-plan-config.js +1 -1
  502. package/packages/level2/client/components/subscription-plan/subscriptions.js +1 -1
  503. package/packages/level2/client/components/wizard/Wizard.funcs.js +1 -1
  504. package/packages/level2/client/components/wizard/WizardStepper.funcs.js +1 -1
  505. package/packages/level2/client/components/wizard/config/wizard-edit-resource-config.js +1 -1
  506. package/packages/level2/client/pages/dashboard-page/DashboardPage.funcs.js +1 -1
  507. package/packages/level2/client/pages/edit-user-by-id-page/EditUserByIdPage.js +4 -3
  508. package/packages/level2/client/pages/microsoft-page/MicrosoftPage.funcs.js +1 -1
  509. package/packages/level2/client/pages/screenshot-page/TestScreenshotPage.funcs.js +1 -1
  510. package/packages/level2/client/pages/view-page/ViewPage.funcs.js +3 -4
  511. package/packages/level2/client/payments/change-payment-method-field/ChangePaymentMethodField.funcs.js +1 -1
  512. package/packages/level2/client/payments/checkout-form/CheckoutForm.funcs.d.ts +1 -0
  513. package/packages/level2/client/payments/checkout-form/CheckoutForm.funcs.js +3 -2
  514. package/packages/level2/client/payments/checkout-form/CheckoutForm.js +70 -83
  515. package/packages/level2/client/payments/checkout-form/CheckoutFormSubmit.js +3 -12
  516. package/packages/level2/client/payments/payments.js +1 -1
  517. package/packages/level2/client/products/reject-action-funcs.js +1 -1
  518. package/packages/level2/client/website-scan/website-scan-result-social-media.js +1 -1
  519. package/packages/level2/common/addresses/address.resource.js +1 -1
  520. package/packages/level2/common/addresses/country.resource.js +1 -1
  521. package/packages/level2/common/customers/customer.resource.js +1 -1
  522. package/packages/level2/common/demo/company.resource.js +1 -1
  523. package/packages/level2/common/demo/contact.resource.js +1 -1
  524. package/packages/level2/common/demo/deal.resource.js +1 -1
  525. package/packages/level2/common/demo/ticket.resource.js +1 -1
  526. package/packages/level2/common/dev/ai-assistent/ai-assistant.resource.js +1 -1
  527. package/packages/level2/common/dev/custom-permission-resource/custom-permission-resource.resource.js +1 -1
  528. package/packages/level2/common/dev/dev-report.resource.js +1 -1
  529. package/packages/level2/common/dev/friends/friend.resource.js +1 -1
  530. package/packages/level2/common/dev/jobs/job.resource.js +1 -1
  531. package/packages/level2/common/dev/no-permission.resource.js +1 -1
  532. package/packages/level2/common/dev/persons/dev-greeting.resource.js +1 -1
  533. package/packages/level2/common/dev/persons/paper-plane.resource.js +1 -1
  534. package/packages/level2/common/dev/persons/person-to-job.resource.js +1 -1
  535. package/packages/level2/common/dev/persons/person-to-person.resource.js +1 -1
  536. package/packages/level2/common/dev/persons/person.resource-ext.js +1 -1
  537. package/packages/level2/common/dev/persons/person.resource.js +1 -1
  538. package/packages/level2/common/dev/persons/phone-brand.resource.js +1 -1
  539. package/packages/level2/common/dev/persons/ping.resource.js +1 -1
  540. package/packages/level2/common/dev/singleton-dev-sandbox.resource.js +1 -1
  541. package/packages/level2/common/fd/fd-meta-toolbox/status-board/status-board.resource.js +1 -1
  542. package/packages/level2/common/fd/fd-toolbox-web/forms/form-field-bank.resource.js +1 -1
  543. package/packages/level2/common/fd/fd-toolbox-web/forms/form-field-category.resource.js +1 -1
  544. package/packages/level2/common/fd/fd-toolbox-web/forms/form-field-submission.resource.js +1 -1
  545. package/packages/level2/common/fd/fd-toolbox-web/forms/form-field-to-form-section.resource.js +1 -1
  546. package/packages/level2/common/fd/fd-toolbox-web/forms/form-field.resource.js +1 -1
  547. package/packages/level2/common/fd/fd-toolbox-web/forms/form-section.resource.js +1 -1
  548. package/packages/level2/common/fd/fd-toolbox-web/forms/form-submission.resource.js +1 -1
  549. package/packages/level2/common/fd/fd-toolbox-web/forms/form.resource.js +1 -1
  550. package/packages/level2/common/fd/fd-toolbox-web/localization/language.resource.js +1 -1
  551. package/packages/level2/common/fd/fd-toolbox-web/localization/localization-string.resource.js +1 -1
  552. package/packages/level2/common/hd/resources/hd-product.resource.js +1 -1
  553. package/packages/level2/common/leads/google-place.resource.js +1 -1
  554. package/packages/level2/common/leads/lead-category.resource.js +1 -1
  555. package/packages/level2/common/leads/lead-email.resource.js +1 -1
  556. package/packages/level2/common/leads/lead-group.resource.js +1 -1
  557. package/packages/level2/common/leads/lead-to-lead-category.resource.js +1 -1
  558. package/packages/level2/common/leads/lead-to-lead-group.resource.js +1 -1
  559. package/packages/level2/common/leads/lead.resource.js +1 -1
  560. package/packages/level2/common/leads/lm/google-place.resource-ext.js +1 -1
  561. package/packages/level2/common/models/create-user-input.js +1 -1
  562. package/packages/level2/common/models/edit-other-user-dto.js +1 -1
  563. package/packages/level2/common/models/user-created.js +1 -1
  564. package/packages/level2/common/payments/feature-to-payment-plan.resource.js +1 -1
  565. package/packages/level2/common/payments/payment.resource.js +1 -1
  566. package/packages/level2/common/payments/system-invoice/payment-system-invoice.resource.js +1 -1
  567. package/packages/level2/common/products/product-parameter.resource.js +1 -1
  568. package/packages/level2/common/resources/case.resource2.js +1 -1
  569. package/packages/level2/common/resources/dashboard-report.resource.js +1 -1
  570. package/packages/level2/common/resources/dashboard.resource.js +1 -1
  571. package/packages/level2/common/resources/feed-entry.resource.js +1 -1
  572. package/packages/level2/common/resources/integration-subscription.resource.js +1 -1
  573. package/packages/level2/common/resources/item.resource.js +1 -1
  574. package/packages/level2/common/resources/oauth-service.resource.js +1 -1
  575. package/packages/level2/common/resources/order-line.resource.js +1 -1
  576. package/packages/level2/common/resources/order-transaction.resource.js +1 -1
  577. package/packages/level2/common/resources/order.resource.js +1 -1
  578. package/packages/level2/common/resources/product-category.resource.js +1 -1
  579. package/packages/level2/common/resources/product-media.resource.js +1 -1
  580. package/packages/level2/common/resources/product.resource.js +1 -1
  581. package/packages/level2/common/resources/search.resource.js +1 -1
  582. package/packages/level2/common/resources/searchable-resource.resource.js +1 -1
  583. package/packages/level2/common/resources/system-setting.resource.js +1 -1
  584. package/packages/level2/common/resources/website-scan-result.resource.js +1 -1
  585. package/packages/level2/common/resources/workspace-setting.resource.js +1 -1
  586. package/packages/level2/common/shipment/shipment-provider.resource.js +1 -1
  587. package/packages/level2/common/shipment/shipment.resource.js +1 -1
  588. package/packages/level2/common/stores/store.resource.js +1 -1
  589. package/packages/level2/common/tutorial/student.resource.js +1 -1
  590. package/packages/level2/common/website-scan/analytics-scan.js +1 -1
  591. package/packages/level2/common/website-scan/website-platform-checking.js +1 -1
  592. package/packages/level2/db/adapters/postgres-adapter.js +2 -2
  593. package/packages/level2/db/adapters/sqlite-adapter.js +2 -2
  594. package/packages/level2/db/constants/db-constants.js +1 -1
  595. package/packages/level2/db/db-config.js +1 -1
  596. package/packages/level2/db/db-connection.js +1 -1
  597. package/packages/level2/db/db-schema.js +1 -1
  598. package/packages/level2/db/drizzle-queries.js +1 -1
  599. package/packages/level2/db/guards/db-type-guards.js +1 -1
  600. package/packages/level2/db/utils/run-migration-command.js +1 -1
  601. package/packages/level2/enricher/integrations/google-spreadsheet.js +2 -2
  602. package/packages/level2/fd-app-toolbox/edit-password-form/EditPasswordForm.funcs.js +1 -1
  603. package/packages/level2/fd-app-toolbox/edit-password-form/EditPasswordForm.js +36 -47
  604. package/packages/level2/fd-app-toolbox/edit-user-form/EditUserForm.funcs.js +1 -1
  605. package/packages/level2/fd-app-toolbox/edit-user-form/EditUserForm.js +46 -55
  606. package/packages/level2/fd-app-toolbox/edit-user-sheet/EditUserSheet.funcs.js +1 -1
  607. package/packages/level2/fd-app-toolbox/forgot-password-form/ForgotPasswordForm.funcs.js +1 -1
  608. package/packages/level2/fd-app-toolbox/forgot-password-form/ForgotPasswordForm.js +7 -16
  609. package/packages/level2/fd-app-toolbox/layout/client-layout/client-layout-config.js +1 -1
  610. package/packages/level2/fd-app-toolbox/layout/client-root/ClientRoot.funcs.js +1 -1
  611. package/packages/level2/fd-app-toolbox/layout/sidebar/Sidebar.funcs.js +1 -1
  612. package/packages/level2/fd-app-toolbox/layout/sidebar/sidebar-dropdown-menu/SidebarDropdownMenu.funcs.js +1 -1
  613. package/packages/level2/fd-app-toolbox/layout/sidebar/sidebar-resource-names-cache.js +1 -1
  614. package/packages/level2/fd-app-toolbox/layout/toolbar/Toolbar.funcs.js +1 -1
  615. package/packages/level2/fd-app-toolbox/login-form/LoginForm.funcs.js +1 -1
  616. package/packages/level2/fd-app-toolbox/login-form/LoginForm.js +50 -49
  617. package/packages/level2/fd-app-toolbox/login-form/facebook-login.js +1 -1
  618. package/packages/level2/fd-app-toolbox/login-form/google-login.js +1 -1
  619. package/packages/level2/fd-app-toolbox/login-form/microsoft-login.js +1 -1
  620. package/packages/level2/fd-app-toolbox/login-form/standard-login.js +1 -1
  621. package/packages/level2/fd-app-toolbox/menu/notifications-menu/NotificationMenu.funcs.js +2 -2
  622. package/packages/level2/fd-app-toolbox/menu/notifications-menu/notification-list/NotificationList.funcs.js +1 -1
  623. package/packages/level2/fd-app-toolbox/menu/top-menu/top-menu-item/TopMenuItem.funcs.js +1 -1
  624. package/packages/level2/fd-app-toolbox/menu/user-dropdown-menu/UserDropdownMenu.funcs.js +1 -1
  625. package/packages/level2/fd-app-toolbox/menu/user-dropdown-menu/user-dropdown-menu-item/UserDropdownMenuItem.funcs.js +1 -1
  626. package/packages/level2/fd-app-toolbox/menu/visible-workspace-picker/VisibleWorkspacePicker.funcs.js +1 -1
  627. package/packages/level2/fd-app-toolbox/menu/workspace-picker/WorkspacePicker.funcs.js +1 -1
  628. package/packages/level2/fd-app-toolbox/models/screens-result.js +1 -1
  629. package/packages/level2/fd-app-toolbox/models/searchable-resource-result.js +1 -1
  630. package/packages/level2/fd-app-toolbox/passwords/passwords-api.js +1 -1
  631. package/packages/level2/fd-app-toolbox/providers/ThemeProvider/theme.js +1 -1
  632. package/packages/level2/fd-app-toolbox/register-form/RegisterForm.funcs.js +1 -1
  633. package/packages/level2/fd-app-toolbox/register-form/RegisterForm.js +40 -51
  634. package/packages/level2/fd-app-toolbox/report/Chart.js +2 -2
  635. package/packages/level2/fd-app-toolbox/report/ReportCard.funcs.js +1 -1
  636. package/packages/level2/fd-app-toolbox/report/ReportChart.funcs.js +1 -1
  637. package/packages/level2/fd-app-toolbox/report/ReportComponent.funcs.js +1 -1
  638. package/packages/level2/fd-app-toolbox/reports/dashboard-report-data.resource.js +1 -1
  639. package/packages/level2/fd-app-toolbox/reports/report-chart-series.resource.js +1 -1
  640. package/packages/level2/fd-app-toolbox/reports/report-with-data.resource.js +1 -1
  641. package/packages/level2/fd-app-toolbox/reports/report.resource.js +1 -1
  642. package/packages/level2/fd-app-toolbox/reset-password-form/ResetPasswordForm.funcs.js +1 -1
  643. package/packages/level2/fd-app-toolbox/reset-password-form/ResetPasswordForm.js +10 -18
  644. package/packages/level2/fd-app-toolbox/resources/notification/notification.resource.js +1 -1
  645. package/packages/level2/fd-app-toolbox/resources/status-board/status-board-item.resource.js +1 -1
  646. package/packages/level2/fd-app-toolbox/resources/status-board/status-board-status.resource.js +1 -1
  647. package/packages/level2/fd-app-toolbox/search/Search.funcs.js +1 -1
  648. package/packages/level2/fd-app-toolbox/search/search-dialog/SearchDialog.funcs.js +2 -2
  649. package/packages/level2/fd-app-toolbox/search/search-result/SearchResult.funcs.js +1 -1
  650. package/packages/level2/fd-app-toolbox/search/search-searchable-resource-results/SearchSearchableResourceResult.funcs.js +1 -1
  651. package/packages/level2/fd-app-toolbox/server/base-resources/props/fill-base-resource-props.js +1 -1
  652. package/packages/level2/fd-app-toolbox/server/base-resources/props/fill-workspace-resource-props.js +1 -1
  653. package/packages/level2/fd-app-toolbox/server/infra/workspaces/workspace-db.js +1 -1
  654. package/packages/level2/fd-app-toolbox/server/layout/sidebar/sidebar-resources.js +1 -1
  655. package/packages/level2/fd-app-toolbox/server/users/user-db.js +1 -1
  656. package/packages/level2/fd-app-toolbox/server/workspace/visible-workspaces.js +1 -1
  657. package/packages/level2/fd-app-toolbox/services/web-socket-client.js +1 -1
  658. package/packages/level2/fd-app-toolbox/status-board/StatusBoard.funcs.js +1 -1
  659. package/packages/level2/fd-app-toolbox/user-list/UserList.funcs.js +1 -1
  660. package/packages/level2/fd-component-toolbox/badge-toggle-list/BadgeToggleList.funcs.js +1 -1
  661. package/packages/level2/fd-component-toolbox/big-calendar/BigCalendar.funcs.js +4 -7
  662. package/packages/level2/fd-component-toolbox/button/Button.d.ts +2 -2
  663. package/packages/level2/fd-component-toolbox/button/Button.funcs.js +1 -1
  664. package/packages/level2/fd-component-toolbox/calendar/Calendar.funcs.js +1 -1
  665. package/packages/level2/fd-component-toolbox/client/framework/index.js +3 -3
  666. package/packages/level2/fd-component-toolbox/datepicker/DatePicker.funcs.js +1 -1
  667. package/packages/level2/fd-component-toolbox/dialog/YesOrNoDialog.funcs.js +1 -1
  668. package/packages/level2/fd-component-toolbox/dynamic-layout/DynamicLayoutDragAndDrop.funcs.js +1 -1
  669. package/packages/level2/fd-component-toolbox/fade-out-text/FadeOutText.funcs.js +1 -1
  670. package/packages/level2/fd-component-toolbox/form/Form.js +6 -9
  671. package/packages/level2/fd-component-toolbox/image-radio-group/ImageRadioGroup.js +2 -2
  672. package/packages/level2/fd-component-toolbox/image-radio-group/ImageRadioGroupDialog.js +2 -2
  673. package/packages/level2/fd-component-toolbox/input/Input.d.ts +3 -3
  674. package/packages/level2/fd-component-toolbox/input/Input.funcs.d.ts +2 -2
  675. package/packages/level2/fd-component-toolbox/input/Input.funcs.js +1 -1
  676. package/packages/level2/fd-component-toolbox/list/list-item/ListItem.funcs.js +1 -1
  677. package/packages/level2/fd-component-toolbox/markdown/Markdown.funcs.js +1 -1
  678. package/packages/level2/fd-component-toolbox/markdown/Markdown.js +2 -2
  679. package/packages/level2/fd-component-toolbox/multiselect/Multiselect.funcs.js +1 -1
  680. package/packages/level2/fd-component-toolbox/multiselect/hooks/use-multi-select.js +1 -1
  681. package/packages/level2/fd-component-toolbox/navigation/navigation-item/NavigationItem.funcs.js +1 -1
  682. package/packages/level2/fd-component-toolbox/rich-text/RichText.funcs.js +3 -3
  683. package/packages/level2/fd-component-toolbox/rich-text/rich-text-constants.js +1 -1
  684. package/packages/level2/fd-component-toolbox/sizing/sizing.js +1 -1
  685. package/packages/level2/fd-component-toolbox/switch/Switch.funcs.js +1 -1
  686. package/packages/level2/fd-component-toolbox/textarea/TextArea.funcs.js +1 -1
  687. package/packages/level2/fd-component-toolbox/toaster/Toaster.funcs.js +1 -1
  688. package/packages/level2/meta/api/hooks/use-ui-resource-meta.js +1 -1
  689. package/packages/level2/meta/api/meta-odata.js +1 -1
  690. package/packages/level2/meta/auth/auth-guards.js +1 -1
  691. package/packages/level2/meta/auth/auth-handler.js +1 -1
  692. package/packages/level2/meta/auth/logins.js +1 -1
  693. package/packages/level2/meta/auth/permissions/permission-checker.js +1 -1
  694. package/packages/level2/meta/browsers/base-multi-browser/BaseMultiBrowser.funcs.js +1 -1
  695. package/packages/level2/meta/browsers/base-multi-browser/base-multi-browser-dialog/BaseMultiBrowserDialog.funcs.js +1 -1
  696. package/packages/level2/meta/browsers/browser/Browser.funcs.js +1 -1
  697. package/packages/level2/meta/browsers/browser/browser-dialog/BrowserDialog.funcs.js +1 -1
  698. package/packages/level2/meta/browsers/many-to-many-browser/ManyToManyBrowser.funcs.js +1 -1
  699. package/packages/level2/meta/browsers/multi-browser/MultiBrowser.funcs.js +1 -1
  700. package/packages/level2/meta/card-list/CardList.funcs.js +1 -1
  701. package/packages/level2/meta/card-list/config/card-config.js +1 -1
  702. package/packages/level2/meta/card-list/data-card/DataCard.funcs.js +1 -1
  703. package/packages/level2/meta/card-list/data-card/data-card-content/DataCardContent.funcs.js +1 -1
  704. package/packages/level2/meta/client/framework/hooks.js +1 -1
  705. package/packages/level2/meta/client/framework/index.js +1 -1
  706. package/packages/level2/meta/client/layout.js +1 -1
  707. package/packages/level2/meta/comment/CommentList.funcs.js +1 -1
  708. package/packages/level2/meta/components/edit-image/EditImage.funcs.js +1 -1
  709. package/packages/level2/meta/components/file-upload/FileUpload.funcs.js +1 -1
  710. package/packages/level2/meta/components/multi-list/MultiList.funcs.js +1 -1
  711. package/packages/level2/meta/components/multi-list/MultiList.js +2 -2
  712. package/packages/level2/meta/components/multi-list/use-multi-list-edit-resource-config.js +1 -1
  713. package/packages/level2/meta/components/related-resources/RelatedResources.funcs.js +1 -1
  714. package/packages/level2/meta/components/related-resources/related-property.js +1 -1
  715. package/packages/level2/meta/components/related-resources/related-resources-component.js +1 -1
  716. package/packages/level2/meta/constants/toolbox-users.js +1 -1
  717. package/packages/level2/meta/core/auth-resource-meta.js +1 -1
  718. package/packages/level2/meta/core/property-meta.js +1 -1
  719. package/packages/level2/meta/core/property-types.js +1 -1
  720. package/packages/level2/meta/core/relation.js +1 -1
  721. package/packages/level2/meta/core/resource-description/resource-description.js +1 -1
  722. package/packages/level2/meta/core/resource-description/resource-descriptions.js +1 -1
  723. package/packages/level2/meta/core/resource-meta.js +1 -1
  724. package/packages/level2/meta/core/resource-singletons.js +1 -1
  725. package/packages/level2/meta/core/resources/blob/blob-urls.js +1 -1
  726. package/packages/level2/meta/core/resources/blob/blob.resource.js +1 -1
  727. package/packages/level2/meta/core/resources/comment.resource.js +1 -1
  728. package/packages/level2/meta/core/resources/features/feature.resource.js +1 -1
  729. package/packages/level2/meta/core/resources/payment-plan-feature.resource.js +1 -1
  730. package/packages/level2/meta/core/resources/payment-plan.resource.js +1 -1
  731. package/packages/level2/meta/core/resources/permissions/permission-package-to-permission.resource.js +1 -1
  732. package/packages/level2/meta/core/resources/permissions/permission-package.resource.js +1 -1
  733. package/packages/level2/meta/core/resources/pricing.resource.js +1 -1
  734. package/packages/level2/meta/core/resources/resources/resource-property.resource.js +1 -1
  735. package/packages/level2/meta/core/resources/resources/resource.resource.js +1 -1
  736. package/packages/level2/meta/core/resources/roles/role-feature.resource.js +1 -1
  737. package/packages/level2/meta/core/resources/roles/role-to-permission-package.resource.js +1 -1
  738. package/packages/level2/meta/core/resources/roles/role-to-permission.resource.js +1 -1
  739. package/packages/level2/meta/core/resources/roles/role.resource.js +1 -1
  740. package/packages/level2/meta/core/resources/usage-limit/usage-limit.resource.js +1 -1
  741. package/packages/level2/meta/core/resources/users/user-activity-overview.resource.js +1 -1
  742. package/packages/level2/meta/core/resources/users/user-feature.resource.js +1 -1
  743. package/packages/level2/meta/core/resources/users/user-role.resource.js +1 -1
  744. package/packages/level2/meta/core/resources/users/user-setting.resource.js +1 -1
  745. package/packages/level2/meta/core/resources/users/user-to-workspace.resource.js +1 -1
  746. package/packages/level2/meta/core/resources/users/user-visible-workspace.resource.js +1 -1
  747. package/packages/level2/meta/core/resources/users/user-workspace-invite.resource.js +1 -1
  748. package/packages/level2/meta/core/resources/users/user.resource.js +1 -1
  749. package/packages/level2/meta/core/resources/workspace/workspace-resource.js +1 -1
  750. package/packages/level2/meta/core/resources/workspace/workspace-to-workspace.resource.js +1 -1
  751. package/packages/level2/meta/core/resources/workspace/workspace.resource.js +1 -1
  752. package/packages/level2/meta/core/ui-property-meta-old.js +1 -1
  753. package/packages/level2/meta/crud/permissions/crud-permission-checker.js +1 -1
  754. package/packages/level2/meta/decorators/access-by-user-id.js +1 -1
  755. package/packages/level2/meta/decorators/access-by-workspace-id.js +1 -1
  756. package/packages/level2/meta/decorators/allowed-crud-actions.js +1 -1
  757. package/packages/level2/meta/decorators/big-text.js +1 -1
  758. package/packages/level2/meta/decorators/blob-image.js +1 -1
  759. package/packages/level2/meta/decorators/colorful.js +1 -1
  760. package/packages/level2/meta/decorators/concat-description.js +1 -1
  761. package/packages/level2/meta/decorators/create-only-resource.js +1 -1
  762. package/packages/level2/meta/decorators/currency.js +1 -1
  763. package/packages/level2/meta/decorators/date-only.js +1 -1
  764. package/packages/level2/meta/decorators/db-index.js +1 -1
  765. package/packages/level2/meta/decorators/default-sort.js +1 -1
  766. package/packages/level2/meta/decorators/description-based-on-property-value.js +1 -1
  767. package/packages/level2/meta/decorators/description-property.js +1 -1
  768. package/packages/level2/meta/decorators/display-name.js +1 -1
  769. package/packages/level2/meta/decorators/dynamic.js +1 -1
  770. package/packages/level2/meta/decorators/email.js +1 -1
  771. package/packages/level2/meta/decorators/expand-description-properties.js +1 -1
  772. package/packages/level2/meta/decorators/file-upload.js +1 -1
  773. package/packages/level2/meta/decorators/flags-enum.js +1 -1
  774. package/packages/level2/meta/decorators/get-only-resource.js +1 -1
  775. package/packages/level2/meta/decorators/icon.js +1 -1
  776. package/packages/level2/meta/decorators/integer.js +1 -1
  777. package/packages/level2/meta/decorators/label.js +1 -1
  778. package/packages/level2/meta/decorators/markdown.js +1 -1
  779. package/packages/level2/meta/decorators/not-a-resource.js +1 -1
  780. package/packages/level2/meta/decorators/not-colorful.js +1 -1
  781. package/packages/level2/meta/decorators/not-displayable.js +1 -1
  782. package/packages/level2/meta/decorators/not-edit-displayable.js +1 -1
  783. package/packages/level2/meta/decorators/not-editable-from-outside.js +1 -1
  784. package/packages/level2/meta/decorators/not-filter-displayable.js +1 -1
  785. package/packages/level2/meta/decorators/not-list-displayable.js +1 -1
  786. package/packages/level2/meta/decorators/not-relation.js +1 -1
  787. package/packages/level2/meta/decorators/outside-excluded.js +1 -1
  788. package/packages/level2/meta/decorators/permission-checker-for.js +1 -1
  789. package/packages/level2/meta/decorators/phone-number.js +1 -1
  790. package/packages/level2/meta/decorators/plural-name.js +1 -1
  791. package/packages/level2/meta/decorators/prefer-plural-name.js +1 -1
  792. package/packages/level2/meta/decorators/prefer-singular-name.js +1 -1
  793. package/packages/level2/meta/decorators/priority.js +1 -1
  794. package/packages/level2/meta/decorators/required-if-other-are-present.js +1 -1
  795. package/packages/level2/meta/decorators/required-if-prop-has-value.js +1 -1
  796. package/packages/level2/meta/decorators/required.js +1 -1
  797. package/packages/level2/meta/decorators/resource-id.js +1 -1
  798. package/packages/level2/meta/decorators/resource-property-id.js +1 -1
  799. package/packages/level2/meta/decorators/rich-text.js +1 -1
  800. package/packages/level2/meta/decorators/searchable.js +1 -1
  801. package/packages/level2/meta/decorators/singleton.js +1 -1
  802. package/packages/level2/meta/decorators/transient-resource.js +1 -1
  803. package/packages/level2/meta/decorators/ui-priority.js +1 -1
  804. package/packages/level2/meta/decorators/ui-relation-priority.js +1 -1
  805. package/packages/level2/meta/decorators/unique.js +1 -1
  806. package/packages/level2/meta/decorators/url.js +1 -1
  807. package/packages/level2/meta/edit-resource/EditResource.funcs.js +1 -1
  808. package/packages/level2/meta/edit-resource/EditResourceHeader.funcs.js +1 -1
  809. package/packages/level2/meta/edit-resource/EditResourceSheet.funcs.js +1 -1
  810. package/packages/level2/meta/edit-resource/EditResourceTabs.funcs.js +1 -1
  811. package/packages/level2/meta/edit-resource/apply-value-changes.js +1 -1
  812. package/packages/level2/meta/edit-resource/config/custom-filter-config-provider.d.ts +4 -0
  813. package/packages/level2/meta/edit-resource/config/custom-filter-config-provider.js +4 -0
  814. package/packages/level2/meta/edit-resource/config/edit-resource-config.js +1 -1
  815. package/packages/level2/meta/edit-resource/config/edit-resource-configs.js +1 -1
  816. package/packages/level2/meta/edit-resource/config/edit-resource-property-config.js +1 -1
  817. package/packages/level2/meta/edit-resource/config/resource-list-config.js +1 -1
  818. package/packages/level2/meta/edit-resource/edit-link/EditLink.funcs.js +1 -1
  819. package/packages/level2/meta/edit-resource/edit-resource-dialog/EditResourceDialog.funcs.js +1 -1
  820. package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourceBlobField.funcs.js +1 -1
  821. package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourceEnumField.funcs.js +1 -1
  822. package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourceFlagsEnumField.funcs.js +1 -1
  823. package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourceImageField.funcs.js +1 -1
  824. package/packages/level2/meta/edit-resource/edit-resource-property-block/EditResourcePropertyBlock.funcs.js +1 -1
  825. package/packages/level2/meta/edit-resource/edit-resource-property-field/EditResourcePropertyField.funcs.js +1 -1
  826. package/packages/level2/meta/edit-resource/edit-resource-validation.js +1 -1
  827. package/packages/level2/meta/edit-resource/edit-resources-constants.js +1 -1
  828. package/packages/level2/meta/edit-resource/hooks/use-edit-resource-ref.js +1 -1
  829. package/packages/level2/meta/edit-resource/save-complete-context.js +1 -1
  830. package/packages/level2/meta/edit-resource/services/blob-components.js +1 -1
  831. package/packages/level2/meta/edit-resource/services/edit-resource-components.js +1 -1
  832. package/packages/level2/meta/edit-resource/services/edit-resource-relations.js +1 -1
  833. package/packages/level2/meta/edit-resource/services/edit-resources.js +1 -1
  834. package/packages/level2/meta/edit-resource/services/form-validations.js +1 -1
  835. package/packages/level2/meta/edit-resource/services/property-metas.js +1 -1
  836. package/packages/level2/meta/edit-resource/services/use-edit-resource-config.js +1 -1
  837. package/packages/level2/meta/fd-meta-toolbox-service.js +1 -1
  838. package/packages/level2/meta/filtering/filter/Filter.funcs.js +1 -1
  839. package/packages/level2/meta/filtering/filter/filters/boolean-filter/BooleanFilter.funcs.js +1 -1
  840. package/packages/level2/meta/filtering/resource-filter-list/ResourceFilterList.funcs.js +1 -1
  841. package/packages/level2/meta/filtering/resource-filter-list/resource-filter-list-ids.js +1 -1
  842. package/packages/level2/meta/filtering/resource-filter-list/resource-filter-lists.js +1 -1
  843. package/packages/level2/meta/filtering/resource-filter-list/use-resource-filter-list-display.js +1 -1
  844. package/packages/level2/meta/layout/events.js +1 -1
  845. package/packages/level2/meta/meta-providers.js +1 -1
  846. package/packages/level2/meta/meta-sort.js +1 -1
  847. package/packages/level2/meta/models/user-base-resource.js +1 -1
  848. package/packages/level2/meta/models/user-workspace-base-resource.js +1 -1
  849. package/packages/level2/meta/odata/expands.js +1 -1
  850. package/packages/level2/meta/odata/odata-selects.js +1 -1
  851. package/packages/level2/meta/one-to-many-relations.js +1 -1
  852. package/packages/level2/meta/page/use-set-title.js +1 -1
  853. package/packages/level2/meta/page/use-title.js +1 -1
  854. package/packages/level2/meta/public-api.d.ts +14 -0
  855. package/packages/level2/meta/public-api.js +15 -0
  856. package/packages/level2/meta/relations/many-to-many-info.js +1 -1
  857. package/packages/level2/meta/relations/meta-relations.js +1 -1
  858. package/packages/level2/meta/resource-list/ResourceList.funcs.js +4 -3
  859. package/packages/level2/meta/resource-list/ResourceList.js +6 -11
  860. package/packages/level2/meta/resource-list/resource-list-cell-element-ids.js +1 -1
  861. package/packages/level2/meta/resource-list/resource-list-checkers.js +1 -1
  862. package/packages/level2/meta/resource-list/resource-list-configs.js +1 -1
  863. package/packages/level2/meta/resource-list/resource-list-header/ResourceListHeader.funcs.js +1 -1
  864. package/packages/level2/meta/resource-list/resource-list-hooks.js +1 -1
  865. package/packages/level2/meta/resource-list/resource-list-persist-state.js +1 -1
  866. package/packages/level2/meta/resource-list/resource-lists.js +1 -1
  867. package/packages/level2/meta/resource-list/use-resource-list-config.js +1 -1
  868. package/packages/level2/meta/resource-providers.js +1 -1
  869. package/packages/level2/meta/resources/session/session.resource.js +1 -1
  870. package/packages/level2/meta/server/api/odata/odata-expression-operators.js +1 -1
  871. package/packages/level2/meta/server/api/odata/odata-expressions.js +1 -1
  872. package/packages/level2/meta/server/api/odata/odata-filters-helpers.js +1 -1
  873. package/packages/level2/meta/server/api/odata/odata-filters.js +1 -1
  874. package/packages/level2/meta/server/api/odata/odata-metas.js +1 -1
  875. package/packages/level2/meta/server/api/odata/odata-parsers.js +1 -1
  876. package/packages/level2/meta/server/api/odata/odata.js +1 -1
  877. package/packages/level2/meta/server/auth/auth-guard.js +1 -1
  878. package/packages/level2/meta/server/auth/fd-sessions.js +1 -1
  879. package/packages/level2/meta/server/auth/permissions/resource-permission-checker-provider.js +1 -1
  880. package/packages/level2/meta/server/auth/role-db/get-all-including-user-to-roles.js +1 -1
  881. package/packages/level2/meta/server/auth/session-access.js +1 -1
  882. package/packages/level2/meta/server/auth/session-validation.js +1 -1
  883. package/packages/level2/meta/server/auth/session.js +1 -1
  884. package/packages/level2/meta/server/auth/users/current-user-id-provider.js +1 -1
  885. package/packages/level2/meta/server/basic-crud/crud-api.js +1 -1
  886. package/packages/level2/meta/server/basic-crud/crud.js +1 -1
  887. package/packages/level2/meta/server/basic-crud/cruds.js +1 -1
  888. package/packages/level2/meta/server/basic-crud/helpers/crud-event-handler.js +1 -1
  889. package/packages/level2/meta/server/basic-crud/helpers/cruds-permission-checker.js +1 -1
  890. package/packages/level2/meta/server/basic-crud/helpers/prepare-many-to-many-resource.js +1 -1
  891. package/packages/level2/meta/server/basic-crud/related-resource-db.js +1 -1
  892. package/packages/level2/meta/server/basic-crud/relation-syncs.js +1 -1
  893. package/packages/level2/meta/server/basic-crud/resource-crud-handlers.js +1 -1
  894. package/packages/level2/meta/server/basic-crud/resource-meta-handlers.js +1 -1
  895. package/packages/level2/meta/server/controllers/generic-controllers/crud-controller.js +1 -1
  896. package/packages/level2/meta/server/db/db.js +1 -1
  897. package/packages/level2/meta/server/db/init-db.js +1 -1
  898. package/packages/level2/meta/server/db/schema/schema-adapter.js +1 -1
  899. package/packages/level2/meta/server/entities/edit-base-resources.js +1 -1
  900. package/packages/level2/meta/server/entities/edit-workspace.js +1 -1
  901. package/packages/level2/meta/server/integration-platforms/fd-integration-cache.js +1 -1
  902. package/packages/level2/meta/server/integration-platforms/integration-db.js +1 -1
  903. package/packages/level2/meta/server/integration-platforms/integration-events.js +1 -1
  904. package/packages/level2/meta/server/messaging/messages.js +1 -1
  905. package/packages/level2/meta/server/meta-core/constants/metas.js +1 -1
  906. package/packages/level2/meta/server/meta-core/constants/resource-ids.js +1 -1
  907. package/packages/level2/meta/server/meta-core/crud/crud-update-config.js +1 -1
  908. package/packages/level2/meta/server/meta-core/crud/search.js +1 -1
  909. package/packages/level2/meta/server/meta-core/display-name.js +1 -1
  910. package/packages/level2/meta/server/meta-url-service.js +1 -1
  911. package/packages/level2/meta/server/models/roles/role-to-permission-package-db.js +1 -1
  912. package/packages/level2/meta/server/permission/permission-checker.js +1 -1
  913. package/packages/level2/meta/server/permission/permission-data-provider.js +1 -1
  914. package/packages/level2/meta/server/permission/permission-package-to-permission-db.js +1 -1
  915. package/packages/level2/meta/server/permission/permissions.js +1 -1
  916. package/packages/level2/meta/server/permission/user-permissions-builder.js +1 -1
  917. package/packages/level2/meta/server/props/meta-property-filters.js +1 -1
  918. package/packages/level2/meta/server/props/property-meta-config-provider.js +1 -1
  919. package/packages/level2/meta/server/props/property-names.js +1 -1
  920. package/packages/level2/meta/server/props/required-properties.js +1 -1
  921. package/packages/level2/meta/server/providers/current-workspace-id-provider.js +1 -1
  922. package/packages/level2/meta/server/relations/many-to-many-relations.js +1 -1
  923. package/packages/level2/meta/server/relations/relations.js +1 -1
  924. package/packages/level2/meta/server/repositories/odata-db.js +1 -1
  925. package/packages/level2/meta/server/resources/crud-resources.js +1 -1
  926. package/packages/level2/meta/server/resources/dynamic-properties.js +1 -1
  927. package/packages/level2/meta/server/resources/init-internal-resource-metas-from-json.js +2 -2
  928. package/packages/level2/meta/server/resources/internal-resource-meta.js +1 -1
  929. package/packages/level2/meta/server/resources/resource-checker.js +1 -1
  930. package/packages/level2/meta/server/resources/resource-meta-plugin.js +2 -2
  931. package/packages/level2/meta/server/resources/searchable-resources-api.js +1 -1
  932. package/packages/level2/meta/server/resources/searchable-resources.js +1 -1
  933. package/packages/level2/meta/server/services/crud-actions.js +1 -1
  934. package/packages/level2/meta/server/services/metas.js +1 -1
  935. package/packages/level2/meta/server/services/permission-check-config-provider.js +1 -1
  936. package/packages/level2/meta/server/services/property-meta.js +1 -1
  937. package/packages/level2/meta/server/services/property-metas.js +1 -1
  938. package/packages/level2/meta/server/services/resource-name-converter.js +1 -1
  939. package/packages/level2/meta/server/services/resource-provider-db.js +1 -1
  940. package/packages/level2/meta/server/services/resource-provider-defaults.js +1 -1
  941. package/packages/level2/meta/server/services/resource-provider-expands.js +1 -1
  942. package/packages/level2/meta/server/services/resource-provider-permissions.js +1 -1
  943. package/packages/level2/meta/server/services/resource-provider.js +1 -1
  944. package/packages/level2/meta/server/ui/meta-api.js +1 -1
  945. package/packages/level2/meta/server/ui/ui-metas-api.js +1 -1
  946. package/packages/level2/meta/server/ui/ui-metas.js +1 -1
  947. package/packages/level2/meta/server/validations/meta-validations.js +2 -2
  948. package/packages/level2/meta/server/value-checker.js +2 -2
  949. package/packages/level2/meta/server/web/current-url.js +1 -1
  950. package/packages/level2/meta/server/web/drizzle-guards.js +1 -1
  951. package/packages/level2/meta/server/web/drizzle.js +1 -1
  952. package/packages/level2/meta/server/web/http-api-wrapper.js +1 -1
  953. package/packages/level2/meta/server/web/reduce-data.js +1 -1
  954. package/packages/level2/meta/server/web/responses.js +1 -1
  955. package/packages/level2/meta/server/workspace/get-visible-workspaces-cache-key.js +1 -1
  956. package/packages/level2/meta/services/client-environment.js +1 -1
  957. package/packages/level2/meta/services/filter-components.js +1 -1
  958. package/packages/level2/meta/services/meta-navigations.js +1 -1
  959. package/packages/level2/meta/services/property-values.js +1 -1
  960. package/packages/level2/meta/services/resource-filters.js +1 -1
  961. package/packages/level2/meta/services/resource-name-client-converter.js +1 -1
  962. package/packages/level2/meta/services/window.js +1 -1
  963. package/packages/level2/meta/state/base-state-functions.js +1 -1
  964. package/packages/level2/meta/subscription-plan/fetch-active-or-trial-subscription.js +1 -1
  965. package/packages/level2/meta/subscription-plan/subscription.resource.js +1 -1
  966. package/packages/level2/meta/table/Table.funcs.js +1 -1
  967. package/packages/level2/meta/table/body/TableBody.funcs.d.ts +1 -1
  968. package/packages/level2/meta/table/body/TableBody.funcs.js +1 -1
  969. package/packages/level2/meta/table/body/TableBody.js +2 -2
  970. package/packages/level2/meta/table/body-cell/ActionBodyCell.funcs.js +1 -1
  971. package/packages/level2/meta/table/body-cell/BlobBodyCell.funcs.js +1 -1
  972. package/packages/level2/meta/table/body-cell/BodyCell.funcs.js +1 -1
  973. package/packages/level2/meta/table/body-cell/BodyCellArrayTooltip.funcs.js +1 -1
  974. package/packages/level2/meta/table/body-cell/BodyCellArrayTooltip.js +9 -6
  975. package/packages/level2/meta/table/body-cell/MultiselectCellTemplate.funcs.js +1 -1
  976. package/packages/level2/meta/table/body-cell/ViewCell.funcs.js +1 -1
  977. package/packages/level2/meta/table/body-row/TableBodyRow.funcs.js +1 -1
  978. package/packages/level2/meta/table/csv-converter.js +1 -1
  979. package/packages/level2/meta/table/header/TableHeader.funcs.js +1 -1
  980. package/packages/level2/meta/table/header-cell/TableHeaderActionCell.funcs.js +1 -1
  981. package/packages/level2/meta/table/header-cell/TableHeaderCell.funcs.js +1 -1
  982. package/packages/level2/meta/table/pager/Pager.funcs.js +1 -1
  983. package/packages/level2/meta/table/services/fd-private-paging.js +1 -1
  984. package/packages/level2/meta/table/services/fd-table-private-column-calculation.js +1 -1
  985. package/packages/level2/meta/table/services/fd-table-private-columns.js +1 -1
  986. package/packages/level2/meta/table/services/fd-table-private-create-columns.js +1 -1
  987. package/packages/level2/meta/table/services/fd-table-private-properties.js +1 -1
  988. package/packages/level2/meta/table/services/fd-table-private-resize-columns.js +1 -1
  989. package/packages/level2/meta/table/services/fd-table-private-rows.js +1 -1
  990. package/packages/level2/meta/table/services/fd-table-private-sorting.js +1 -1
  991. package/packages/level2/meta/table/services/table-private-cell.js +1 -1
  992. package/packages/level2/meta/table/table-constants.js +1 -1
  993. package/packages/level2/meta/table/table-custom-action/TableCustomAction.funcs.js +1 -1
  994. package/packages/level2/meta/ui/ui-relation.js +1 -1
  995. package/packages/level2/meta/ui-meta-providers.js +1 -1
  996. package/packages/level2/meta/ui-resource-meta.js +1 -1
  997. package/packages/level2/meta/view/ViewSheet.funcs.js +1 -1
  998. package/packages/level2/npm-commands/gen-dynamic-handlers-map/generate-dynamic-handlers-map.js +3 -3
  999. package/packages/level2/npm-commands/gen-meta/generate-meta.js +2 -2
  1000. package/packages/level2/npm-commands/gen-meta/generate-tsconfig.js +2 -2
  1001. package/packages/level2/npm-commands/gen-schema/gen-schema.js +1 -1
  1002. package/packages/level2/npm-commands/gen-schema/transpile-schema.js +1 -1
  1003. package/packages/level2/npm-commands/migrate-db/migrate-db.js +1 -1
  1004. package/packages/level2/npm-commands/run-command/index.js +3 -3
  1005. package/packages/level2/npm-commands/seed-db/seed-db.js +1 -1
  1006. package/packages/level2/npm-commands/server/db/fd-db-initializer.js +1 -1
  1007. package/packages/level2/other/scrapping/scrape.command.js +1 -1
  1008. package/packages/level2/other/scrapping/scrapper-config.js +1 -1
  1009. package/packages/level2/other/scrapping/scrappers.js +2 -2
  1010. package/packages/level2/server/addresses/address-db.js +1 -1
  1011. package/packages/level2/server/addresses/address-master-data.js +1 -1
  1012. package/packages/level2/server/addresses/country-db.js +1 -1
  1013. package/packages/level2/server/addresses/country-master-data.js +1 -1
  1014. package/packages/level2/server/ai/ai-generated-text.js +1 -1
  1015. package/packages/level2/server/auth/dev-demo-permissions.js +1 -1
  1016. package/packages/level2/server/auth/lm-permission-master-data.js +1 -1
  1017. package/packages/level2/server/auth/oauth-service-db.js +1 -1
  1018. package/packages/level2/server/auth/permission-master-data.js +1 -1
  1019. package/packages/level2/server/auth/permission-role-mapping.js +1 -1
  1020. package/packages/level2/server/auth/role-db.js +1 -1
  1021. package/packages/level2/server/auth/role-master-data.js +1 -1
  1022. package/packages/level2/server/auth/role-to-permission-master-data.js +1 -1
  1023. package/packages/level2/server/auth/role-to-permission-package.handlers.js +1 -1
  1024. package/packages/level2/server/auth/role-to-permission.handlers.js +1 -1
  1025. package/packages/level2/server/auth/role.handlers.js +1 -1
  1026. package/packages/level2/server/auth/sign-in-api.js +1 -1
  1027. package/packages/level2/server/auth/sign-out-api.js +1 -1
  1028. package/packages/level2/server/auth/sign-up-api.js +1 -1
  1029. package/packages/level2/server/blob/blob-db.js +2 -2
  1030. package/packages/level2/server/business-profile/business-profile-api.js +1 -1
  1031. package/packages/level2/server/comments/comment-db.js +1 -1
  1032. package/packages/level2/server/comments/comment-master-data.js +1 -1
  1033. package/packages/level2/server/customers/customer-db.js +1 -1
  1034. package/packages/level2/server/customers/customer-master-data.js +1 -1
  1035. package/packages/level2/server/dashboards/dashboard-db.js +1 -1
  1036. package/packages/level2/server/dashboards/dashboard-master-data.js +1 -1
  1037. package/packages/level2/server/dashboards/dashboard-report-db.js +1 -1
  1038. package/packages/level2/server/dashboards/dashboard-report-master-data.js +1 -1
  1039. package/packages/level2/server/db/db.js +1 -1
  1040. package/packages/level2/server/demo/companies/company-db.js +1 -1
  1041. package/packages/level2/server/demo/companies/company-master-data.js +1 -1
  1042. package/packages/level2/server/demo/contacts/contact-db.js +1 -1
  1043. package/packages/level2/server/demo/contacts/contact-master-data.js +1 -1
  1044. package/packages/level2/server/demo/deals/deal-db.js +1 -1
  1045. package/packages/level2/server/demo/deals/deal-master-data.js +1 -1
  1046. package/packages/level2/server/demo/tickets/ticket-db.js +1 -1
  1047. package/packages/level2/server/demo/tickets/ticket-master-data.js +1 -1
  1048. package/packages/level2/server/dev/ai-assistant/ai-assistant-db.js +1 -1
  1049. package/packages/level2/server/dev/ai-assistant/ai-assistant-master-data.js +1 -1
  1050. package/packages/level2/server/dev/ai-assistant/ai-assistant-mother.js +1 -1
  1051. package/packages/level2/server/dev/dev-greeting/dev-greeting-master-data.js +1 -1
  1052. package/packages/level2/server/dev/dev-greeting/dev-greeting-mother.js +1 -1
  1053. package/packages/level2/server/dev/friends/friend-db.js +1 -1
  1054. package/packages/level2/server/dev/friends/friend-master-data.js +1 -1
  1055. package/packages/level2/server/dev/friends/friend-mother.js +1 -1
  1056. package/packages/level2/server/dev/friends/friend-utils.js +1 -1
  1057. package/packages/level2/server/dev/jobs/job-db.js +1 -1
  1058. package/packages/level2/server/dev/jobs/job-master-data.js +1 -1
  1059. package/packages/level2/server/dev/jobs/job-mother.js +1 -1
  1060. package/packages/level2/server/dev/paper-planes/paper-plane-db.js +1 -1
  1061. package/packages/level2/server/dev/paper-planes/paper-plane-master-data.js +1 -1
  1062. package/packages/level2/server/dev/paper-planes/paper-plane-mother.js +1 -1
  1063. package/packages/level2/server/dev/paper-planes/paper-plane.handlers.js +1 -1
  1064. package/packages/level2/server/dev/persons/person-db.js +1 -1
  1065. package/packages/level2/server/dev/persons/person-master-data.js +1 -1
  1066. package/packages/level2/server/dev/persons/person-mother.js +1 -1
  1067. package/packages/level2/server/dev/persons/person-to-job-db.js +1 -1
  1068. package/packages/level2/server/dev/persons/person-to-job-master-data.js +1 -1
  1069. package/packages/level2/server/dev/persons/person-to-job-mother.js +1 -1
  1070. package/packages/level2/server/dev/persons/person-to-person-db.js +1 -1
  1071. package/packages/level2/server/dev/persons/person-to-person-master-data.js +1 -1
  1072. package/packages/level2/server/dev/persons/person-to-person-mother.js +1 -1
  1073. package/packages/level2/server/dev/persons/person.handlers.js +1 -1
  1074. package/packages/level2/server/dev/phone-brands/phone-brand-db.js +1 -1
  1075. package/packages/level2/server/dev/phone-brands/phone-brand-master-data.js +1 -1
  1076. package/packages/level2/server/dev/phone-brands/phone-brand-mother.js +1 -1
  1077. package/packages/level2/server/dev/pings/ping-db.js +1 -1
  1078. package/packages/level2/server/dev/pings/ping-master-data.js +1 -1
  1079. package/packages/level2/server/dev/pings/ping-mother.js +1 -1
  1080. package/packages/level2/server/example/example-api.js +1 -1
  1081. package/packages/level2/server/export/csv-data-formatter.js +1 -1
  1082. package/packages/level2/server/export/export-api.js +1 -1
  1083. package/packages/level2/server/fd/fd-toolbox-asp-net/models/roles/role-to-permission-db.js +1 -1
  1084. package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission-db.js +1 -1
  1085. package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission-package-db.js +1 -1
  1086. package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission-package-to-db.js +1 -1
  1087. package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission-package-to-permission.handlers.js +1 -1
  1088. package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission-package.handlers.js +1 -1
  1089. package/packages/level2/server/fd/fd-toolbox-web/auth/permissions/permission.handlers.js +1 -1
  1090. package/packages/level2/server/fd/fd-toolbox-web/http/base-http-client.js +1 -1
  1091. package/packages/level2/server/fd/fd-toolbox-web/localization/language/language-db.js +1 -1
  1092. package/packages/level2/server/fd/fd-toolbox-web/localization/language/language-master-data.js +1 -1
  1093. package/packages/level2/server/fd/fd-toolbox-web/logging/log-api.js +1 -1
  1094. package/packages/level2/server/fd/fd-toolbox-web/mailing/fd-emails.js +1 -1
  1095. package/packages/level2/server/fd/fd-toolbox-web/models/reset-password-request.js +1 -1
  1096. package/packages/level2/server/fd/fd-toolbox-web/notifications/notification-db.js +1 -1
  1097. package/packages/level2/server/fd/fd-toolbox-web/permissions/fd-permission-master-data.js +1 -1
  1098. package/packages/level2/server/fd/fd-toolbox-web/permissions/permission-api.js +1 -1
  1099. package/packages/level2/server/fd/fd-toolbox-web/resources/resource-property-db.js +1 -1
  1100. package/packages/level2/server/fd/fd-toolbox-web/seeding/notification-master-data.js +1 -1
  1101. package/packages/level2/server/fd/fd-toolbox-web/seeding/resource-master-data.js +1 -1
  1102. package/packages/level2/server/fd/fd-toolbox-web/seeding/resource-property-master-data.js +1 -1
  1103. package/packages/level2/server/fd/fd-toolbox-web/seeding/workspace-master-data.js +1 -1
  1104. package/packages/level2/server/fd/fd-toolbox-web/services/notifications.js +1 -1
  1105. package/packages/level2/server/fd/fd-toolbox-web/services/socket/web-socket-server.js +1 -1
  1106. package/packages/level2/server/features/feature-db.js +1 -1
  1107. package/packages/level2/server/features/feature-master-data.js +1 -1
  1108. package/packages/level2/server/features/feature-mother.js +1 -1
  1109. package/packages/level2/server/features/features.js +1 -1
  1110. package/packages/level2/server/features/payment-plan-feature-data.js +1 -1
  1111. package/packages/level2/server/features/payment-plan-feature-db.js +1 -1
  1112. package/packages/level2/server/features/status-board-master-data.js +1 -1
  1113. package/packages/level2/server/features/user-feature.handlers.js +1 -1
  1114. package/packages/level2/server/feeds/feed-entry-data.js +1 -1
  1115. package/packages/level2/server/hd/plaid/plaid.js +1 -1
  1116. package/packages/level2/server/html/email.js +1 -1
  1117. package/packages/level2/server/infra/background-jobs/background-jobs.js +2 -2
  1118. package/packages/level2/server/infra/background-jobs/init-jobs.js +1 -1
  1119. package/packages/level2/server/infra/workspaces/workspace-setting-db.js +1 -1
  1120. package/packages/level2/server/integration/data/deleted/integration-deleted-api.js +1 -1
  1121. package/packages/level2/server/integration/data/dynamicfields/integration-dynamicfields-api.js +1 -1
  1122. package/packages/level2/server/integration/integration-api.js +1 -1
  1123. package/packages/level2/server/integration-platforms/integration-resource.js +1 -1
  1124. package/packages/level2/server/integration-platforms/subscription-odata.js +1 -1
  1125. package/packages/level2/server/integrations/aio/blobs.js +2 -2
  1126. package/packages/level2/server/integrations/blob/blob-storage.js +1 -1
  1127. package/packages/level2/server/integrations/google-place/google-place-helpers.js +1 -1
  1128. package/packages/level2/server/integrations/google-place/google-place.handlers.js +1 -1
  1129. package/packages/level2/server/integrations/google-place/google-place.js +1 -1
  1130. package/packages/level2/server/integrations/remote-blob/remote-blob-storage.js +1 -1
  1131. package/packages/level2/server/integrations/screenshot/get-website-screenshots.js +1 -1
  1132. package/packages/level2/server/integrations/screenshot/screenshot-controller.js +1 -1
  1133. package/packages/level2/server/integrations/screenshot/screenshotone/screenshotone-client.js +2 -2
  1134. package/packages/level2/server/integrations/website-scan/scan-social-media-and-email.js +1 -1
  1135. package/packages/level2/server/integrations/website-scan/website-scan-initializer.js +1 -1
  1136. package/packages/level2/server/items/item-db.js +1 -1
  1137. package/packages/level2/server/leads/lead-category-db.js +1 -1
  1138. package/packages/level2/server/leads/lead-category-master-data.js +1 -1
  1139. package/packages/level2/server/leads/lead-db.js +1 -1
  1140. package/packages/level2/server/leads/lead-email-db.js +1 -1
  1141. package/packages/level2/server/leads/lead-email-master-data.js +1 -1
  1142. package/packages/level2/server/leads/lead-group-db.js +1 -1
  1143. package/packages/level2/server/leads/lead-group-master-data.js +1 -1
  1144. package/packages/level2/server/leads/lead-master-data.js +1 -1
  1145. package/packages/level2/server/leads/lead-to-lead-category-db.js +1 -1
  1146. package/packages/level2/server/leads/lead-to-lead-category-master-data.js +1 -1
  1147. package/packages/level2/server/leads/lead-to-lead-group-db.js +1 -1
  1148. package/packages/level2/server/leads/lead-to-lead-group-master-data.js +1 -1
  1149. package/packages/level2/server/leads/lead-to-lead-group.handlers.js +1 -1
  1150. package/packages/level2/server/leads/lead.handlers.js +1 -1
  1151. package/packages/level2/server/leads/services/ai-scan-result-delete.js +1 -1
  1152. package/packages/level2/server/lm/google-place/google-place-to-lead.js +1 -1
  1153. package/packages/level2/server/lm/google-place/save-to-group/save-to-group-api.js +1 -1
  1154. package/packages/level2/server/lm/google-place-scan-website/google-place-scan-website-api.js +1 -1
  1155. package/packages/level2/server/lm/lead-scan-website/lead-scan-website-api.js +1 -1
  1156. package/packages/level2/server/markdown/markdown-api.js +1 -1
  1157. package/packages/level2/server/markdown/markdown.js +1 -1
  1158. package/packages/level2/server/media/media-api.js +2 -2
  1159. package/packages/level2/server/media/media-master-data.js +3 -3
  1160. package/packages/level2/server/notifications/notification.handlers.js +1 -1
  1161. package/packages/level2/server/orders/order-db.js +1 -1
  1162. package/packages/level2/server/orders/order-master-data.js +1 -1
  1163. package/packages/level2/server/orders/order-utils.js +1 -1
  1164. package/packages/level2/server/orders/order.handlers.js +1 -1
  1165. package/packages/level2/server/otheruser/id/otheruser-id-api.js +1 -1
  1166. package/packages/level2/server/otheruser/otheruser-api.js +1 -1
  1167. package/packages/level2/server/password/editpassword/editpassword-api.js +1 -1
  1168. package/packages/level2/server/password/forgotpassword/forgotpassword-api.js +1 -1
  1169. package/packages/level2/server/password/resetpassword/resetpassword-api.js +1 -1
  1170. package/packages/level2/server/payment/method/payment-method-api.js +1 -1
  1171. package/packages/level2/server/payment/verify-fail/payment-verify-fail-api.js +1 -1
  1172. package/packages/level2/server/payment/verify-success/payment-verify-success.js +1 -1
  1173. package/packages/level2/server/payments/payment-plan.handlers.js +2 -2
  1174. package/packages/level2/server/payments/payments/payment-plan-db.js +1 -1
  1175. package/packages/level2/server/payments/payments/payment-plan-master-data.js +1 -1
  1176. package/packages/level2/server/payments/payments/payment-plans.js +1 -1
  1177. package/packages/level2/server/payments/payments/payments-api.js +1 -1
  1178. package/packages/level2/server/payments/payments/payments.js +1 -1
  1179. package/packages/level2/server/payments/payments/pricing-seeding.js +1 -1
  1180. package/packages/level2/server/payments/pricing.handlers.js +1 -1
  1181. package/packages/level2/server/payments/stripe/stripe-sync.js +2 -2
  1182. package/packages/level2/server/payments/stripe/stripes.js +2 -2
  1183. package/packages/level2/server/payments/subscriptions/subscription-db.js +1 -1
  1184. package/packages/level2/server/payments/subscriptions/subscriptions.js +1 -1
  1185. package/packages/level2/server/payments/system-invoice/payment-system-invoice.handlers.js +1 -1
  1186. package/packages/level2/server/product-setup/website-analysiz.js +2 -2
  1187. package/packages/level2/server/products/product-db.js +1 -1
  1188. package/packages/level2/server/products/product-master-data.js +1 -1
  1189. package/packages/level2/server/products/product-media/product-media-db.js +1 -1
  1190. package/packages/level2/server/products/product-media/product-media-master-data.js +1 -1
  1191. package/packages/level2/server/products/product-parameters/product-parameter-mother.js +1 -1
  1192. package/packages/level2/server/reports/report-chart-series-master-data.js +1 -1
  1193. package/packages/level2/server/reports/report-chart-series-mother.js +1 -1
  1194. package/packages/level2/server/reports/report-db.js +1 -1
  1195. package/packages/level2/server/reports/report-master-data.js +1 -1
  1196. package/packages/level2/server/reports/report-mother.js +1 -1
  1197. package/packages/level2/server/reports/report-with-data.handlers.js +1 -1
  1198. package/packages/level2/server/search/search-result-api.js +1 -1
  1199. package/packages/level2/server/search/search-result.js +1 -1
  1200. package/packages/level2/server/search/search.handlers.js +1 -1
  1201. package/packages/level2/server/search/searchable-resource.handlers.js +1 -1
  1202. package/packages/level2/server/seeding/seed-master-data.js +1 -1
  1203. package/packages/level2/server/shipment/shipment-api.js +1 -1
  1204. package/packages/level2/server/shipment/shipment-db.js +1 -1
  1205. package/packages/level2/server/shipment/shipment-master-data.js +1 -1
  1206. package/packages/level2/server/shipment/shipment.handlers.js +1 -1
  1207. package/packages/level2/server/statusboard/statusboard-api.js +1 -1
  1208. package/packages/level2/server/store/store-db.js +1 -1
  1209. package/packages/level2/server/store/store-master-data.js +2 -2
  1210. package/packages/level2/server/subscription/cancel/subscription-cancel-api.js +1 -1
  1211. package/packages/level2/server/subscription/create/subscription-create-api.js +1 -1
  1212. package/packages/level2/server/subscription/update/subscription-update-api.js +1 -1
  1213. package/packages/level2/server/system-settings/system-master-data.js +1 -1
  1214. package/packages/level2/server/system-settings/system-setting-db.js +1 -1
  1215. package/packages/level2/server/test/data/test-data-api.js +1 -1
  1216. package/packages/level2/server/test/data/test-data.js +1 -1
  1217. package/packages/level2/server/upload/upload-api.js +1 -1
  1218. package/packages/level2/server/usage-limit/usage-limit.js +1 -1
  1219. package/packages/level2/server/user-settings/user-setting.handlers.js +1 -1
  1220. package/packages/level2/server/userfeature/isenabled/userfeature-isenabled-api.js +1 -1
  1221. package/packages/level2/server/users/admin-edit-admin.js +1 -1
  1222. package/packages/level2/server/users/auth.js +1 -1
  1223. package/packages/level2/server/users/edit-other-users.js +1 -1
  1224. package/packages/level2/server/users/tokens.js +2 -2
  1225. package/packages/level2/server/users/user-creation-service.js +1 -1
  1226. package/packages/level2/server/users/user-db.js +1 -1
  1227. package/packages/level2/server/users/user-deletions.js +1 -1
  1228. package/packages/level2/server/users/user-feature-db.js +1 -1
  1229. package/packages/level2/server/users/user-feature-predicates.js +1 -1
  1230. package/packages/level2/server/users/user-manager.js +2 -2
  1231. package/packages/level2/server/users/user-master-data.js +1 -1
  1232. package/packages/level2/server/users/user-mother.js +1 -1
  1233. package/packages/level2/server/users/user-role.handlers.js +1 -1
  1234. package/packages/level2/server/users/user-role.js +1 -1
  1235. package/packages/level2/server/users/user-service.js +1 -1
  1236. package/packages/level2/server/users/user-settings/user-setting-db.js +1 -1
  1237. package/packages/level2/server/users/user.handlers.js +1 -1
  1238. package/packages/level2/server/utils/base-resource-properties.js +1 -1
  1239. package/packages/level2/server/utils/check-resource-access-permission.js +1 -1
  1240. package/packages/level2/server/utils/get-user-and-workspace-ids.js +1 -1
  1241. package/packages/level2/server/utils/map-subscription-status-to-db-format.js +1 -1
  1242. package/packages/level2/server/web/http-wrapper.js +1 -1
  1243. package/packages/level2/server/web/initialize.js +1 -1
  1244. package/packages/level2/server/web/responses/create-remote-blob-response.js +1 -1
  1245. package/packages/level2/server/workspace/change-current-workspace.js +1 -1
  1246. package/packages/level2/server/workspace/visible-workspace-api.js +1 -1
  1247. package/packages/level2/server/workspace/workspace-api.js +1 -1
  1248. package/packages/level2/server/workspace/workspace-invite/user-workspace-invite.handlers.js +1 -1
  1249. package/packages/level2/server/workspace/workspace-invite/workspace-user-invites.js +1 -1
  1250. package/packages/test-infra/asserters/edit-asserts.js +1 -1
  1251. package/packages/test-infra/asserters/forgot-password-asserts.js +1 -1
  1252. package/packages/test-infra/asserters/navigation-asserts.js +1 -1
  1253. package/packages/test-infra/asserters/notification-asserts.js +1 -1
  1254. package/packages/test-infra/asserters/search-asserts.js +1 -1
  1255. package/packages/test-infra/asserters/table-asserts.d.ts +1 -0
  1256. package/packages/test-infra/asserters/table-asserts.js +2 -2
  1257. package/packages/test-infra/asserters/ui-asserts.js +1 -1
  1258. package/packages/test-infra/constants/test-data/input-fields-values.js +3 -1
  1259. package/packages/test-infra/constants/ui-tester/checkout-form-test-data.js +2 -1
  1260. package/packages/test-infra/fixtures/custom-test-functions.js +1 -1
  1261. package/packages/test-infra/fixtures/error-tracking-fixture.js +1 -1
  1262. package/packages/test-infra/fixtures/extend-test.js +1 -1
  1263. package/packages/test-infra/monorepo-global-setup.js +1 -1
  1264. package/packages/test-infra/monorepo-global-teardown.js +1 -1
  1265. package/packages/test-infra/page-objects/account-setup-po.js +1 -1
  1266. package/packages/test-infra/page-objects/browser-po.js +1 -1
  1267. package/packages/test-infra/page-objects/checkout-form-po.js +1 -1
  1268. package/packages/test-infra/page-objects/edit-po.js +1 -1
  1269. package/packages/test-infra/page-objects/filter-po.js +1 -1
  1270. package/packages/test-infra/page-objects/forgot-password-po.js +1 -1
  1271. package/packages/test-infra/page-objects/list-po.js +1 -1
  1272. package/packages/test-infra/page-objects/login-po.js +1 -1
  1273. package/packages/test-infra/page-objects/multi-browser-po.js +1 -1
  1274. package/packages/test-infra/page-objects/notification-po.js +1 -1
  1275. package/packages/test-infra/page-objects/payment-plan-po.js +1 -1
  1276. package/packages/test-infra/page-objects/reset-password-po.js +1 -1
  1277. package/packages/test-infra/page-objects/search-po.js +1 -1
  1278. package/packages/test-infra/page-objects/select-workspace-po.js +1 -1
  1279. package/packages/test-infra/page-objects/sidebar-po.js +1 -1
  1280. package/packages/test-infra/page-objects/table-asserts.d.ts +2 -0
  1281. package/packages/test-infra/page-objects/table-asserts.js +2 -2
  1282. package/packages/test-infra/page-objects/toolbar-po.js +1 -1
  1283. package/packages/test-infra/page-objects/user-menu-po.js +1 -1
  1284. package/packages/test-infra/page-objects/user-setting-po.js +1 -1
  1285. package/packages/test-infra/page-objects/view-po.js +1 -1
  1286. package/packages/test-infra/playwright-setup/global-setup.js +1 -1
  1287. package/packages/test-infra/playwright-setup/global-teardown.js +1 -1
  1288. package/packages/test-infra/test-data/crud-tests/crud-test-data-factory.js +1 -1
  1289. package/packages/test-infra/test-data/crud-tests/crud-test-data.js +1 -1
  1290. package/packages/test-infra/test-data/crud-tests/relation-sync-info-provider.js +1 -1
  1291. package/packages/test-infra/test-data/dev/friends/friends-mother.js +1 -1
  1292. package/packages/test-infra/test-data/dev/persons/person-mother.js +1 -1
  1293. package/packages/test-infra/test-data/dev/persons/phone-brand-mother.js +1 -1
  1294. package/packages/test-infra/test-data/integration-tests/base-http-client.js +2 -2
  1295. package/packages/test-infra/test-data/integration-tests/http-client.js +2 -2
  1296. package/packages/test-infra/test-data/integration-tests/result-comparer.js +1 -1
  1297. package/packages/test-infra/test-data/integration-tests/workspace.js +1 -1
  1298. package/packages/test-infra/test-data/meta/person-property-metas.js +1 -1
  1299. package/packages/test-infra/test-data/meta/resource-meta-mother.js +1 -1
  1300. package/packages/test-infra/test-data/meta/ui-meta-mother.js +1 -1
  1301. package/packages/test-infra/test-data/meta/ui-property-meta-mother.js +1 -1
  1302. package/packages/test-infra/test-data/seed-test-data.js +1 -1
  1303. package/packages/test-infra/ui-tester/global-ui-test.js +1 -1
  1304. package/packages/test-infra/ui-tester/ui-tester.js +3 -3
  1305. package/packages/tools/string-duplication/handlers.js +1 -1
  1306. package/packages/tools/string-duplication/index.d.ts +13 -1
  1307. package/packages/tools/string-duplication/index.js +11 -49
  1308. package/packages/tools/string-duplication/normalizer.js +1 -1
  1309. package/packages/tools/string-duplication/reporter.js +3 -1
  1310. package/packages/tools/string-duplication/resolver.js +3 -2
  1311. package/packages/tools/string-duplication/string-extractor.js +3 -2
  1312. package/src/app/loading.js +3 -2
  1313. package/src/hd/footer/HdFooter.js +3 -2
  1314. package/src/lm/ai-scan/AiScanAction.funcs.js +1 -1
  1315. package/src/lm/google-place/action-dropdown/GooglePlaceActionDropdown.funcs.js +1 -1
  1316. package/src/lm/google-place/actions/GooglePlaceSaveToGroupAction.funcs.js +1 -1
  1317. package/src/lm/google-place/actions/google-place-delete-action.js +1 -1
  1318. package/src/lm/google-place/actions/google-place-take-screenshot-action.js +1 -1
  1319. package/src/lm/google-place/cell-templates/GooglePlaceEmailsCellTemplate.funcs.js +1 -1
  1320. package/src/lm/google-place/cell-templates/GooglePlaceScanAction.funcs.js +1 -1
  1321. package/src/lm/lead/action-dropdown/LeadActionDropdown.funcs.js +1 -1
  1322. package/src/lm/lead/action-dropdown/lead-dropdown-actions.js +1 -1
  1323. package/src/lm/lead/actions/export-leads-action/export-leads-action.js +1 -1
  1324. package/src/lm/lead/actions/move-to-group-action/LeadMoveToGroupAction.funcs.js +1 -1
  1325. package/src/lm/lead/actions/save-to-group-action/lead-save-to-group-action.js +1 -1
  1326. package/src/lm/lead/actions/take-screenshot-action/lead-take-screenshot-action.js +1 -1
  1327. package/src/lm/lead/cell-templates/LeadScanAction.funcs.js +1 -1
  1328. package/src/lm/lead-group/table-custom-action/lead-group-table-custom-action.js +1 -1
  1329. package/src/lm/pages/HomePage.funcs.js +1 -1
  1330. package/test-infra/index.d.ts +2 -2
  1331. package/test-infra/index.js +2 -2
  1332. package/undocumented/index.d.ts +236 -136
  1333. package/undocumented/index.js +181 -168
  1334. package/packages/fd-toolbox/infra/env-setting-types.d.ts +0 -5
  1335. package/packages/fd-toolbox/infra/env-setting-types.js +0 -4
  1336. package/packages/flint/infra/ast-helpers/array-analysis.js +0 -8
  1337. package/packages/flint/infra/ast-helpers/casing-analysis.js +0 -4
  1338. package/packages/flint/infra/ast-helpers/enum-analysis.js +0 -12
  1339. package/packages/flint/infra/ast-helpers/eslint-analysis.js +0 -6
  1340. package/packages/flint/infra/ast-helpers/expression-analysis.js +0 -7
  1341. package/packages/flint/infra/ast-helpers/formatting-analysis.js +0 -6
  1342. package/packages/flint/infra/ast-helpers/function-analysis.js +0 -7
  1343. package/packages/flint/infra/ast-helpers/jsx-analysis.js +0 -7
  1344. package/packages/flint/infra/ast-helpers/module-analysis.js +0 -11
  1345. package/packages/flint/infra/ast-helpers/name-analysis.js +0 -9
  1346. package/packages/flint/infra/ast-helpers/nullish-analysis.js +0 -6
  1347. package/packages/flint/infra/ast-helpers/number-analysis.js +0 -7
  1348. package/packages/flint/infra/ast-helpers/object-analysis.js +0 -6
  1349. package/packages/flint/infra/ast-helpers/scope-analysis.js +0 -10
  1350. package/packages/flint/infra/ast-helpers/string-analysis.js +0 -9
  1351. package/packages/flint/infra/ast-helpers/tree-analysis.js +0 -6
  1352. package/packages/flint/infra/ast-helpers/type-analysis.js +0 -8
  1353. package/packages/flint/infra/ast-helpers/type-guards.js +0 -10
  1354. package/packages/flint/infra/ast-helpers/variable-analysis.d.ts +0 -2
  1355. package/packages/flint/infra/ast-helpers/variable-analysis.js +0 -7
  1356. package/packages/flint/infra/ast-helpers/visitors.js +0 -4
  1357. package/packages/flint/infra/utils/create-eslint-rule.js +0 -6
  1358. package/packages/flint/rules/naming/must-use-singlewithwarning-instead-of-indexing-first-element.d.ts +0 -3
  1359. package/packages/flint/rules/naming/must-use-singlewithwarning-instead-of-indexing-first-element.js +0 -8
  1360. /package/packages/flint/infra/{ast-helpers → analysis}/array-analysis.d.ts +0 -0
  1361. /package/packages/flint/infra/{ast-helpers → analysis}/casing-analysis.d.ts +0 -0
  1362. /package/packages/flint/infra/{ast-helpers → analysis}/enum-analysis.d.ts +0 -0
  1363. /package/packages/flint/infra/{ast-helpers → analysis}/eslint-analysis.d.ts +0 -0
  1364. /package/packages/flint/infra/{ast-helpers → analysis}/formatting-analysis.d.ts +0 -0
  1365. /package/packages/flint/infra/{ast-helpers → analysis}/jsx-analysis.d.ts +0 -0
  1366. /package/packages/flint/infra/{ast-helpers → analysis}/module-analysis.d.ts +0 -0
  1367. /package/packages/flint/infra/{ast-helpers → analysis}/nullish-analysis.d.ts +0 -0
  1368. /package/packages/flint/infra/{ast-helpers → analysis}/number-analysis.d.ts +0 -0
  1369. /package/packages/flint/infra/{ast-helpers → analysis}/string-analysis.d.ts +0 -0
  1370. /package/packages/flint/infra/{ast-helpers → analysis}/tree-analysis.d.ts +0 -0
  1371. /package/packages/flint/infra/{utils/create-eslint-rule.d.ts → create-eslint-rule.d.ts} +0 -0
@@ -1,8 +1,7 @@
1
1
  'use strict';
2
- import { createEslintRule } from '@flint/infra/utils/create-eslint-rule';
3
- import { nodeTypes } from '@flint/infra/ast-helpers/function-analysis';
4
- import { isIdentifier } from '@flint/infra/ast-helpers';
2
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
3
+ import { nodeTypes, isIdentifier } from '@flint/infra/analysis';
5
4
 
6
- var __defProp=Object['defineProperty'],__name=(_0x12febc,_0x42fb2f)=>__defProp(_0x12febc,'name',{'value':_0x42fb2f,'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(_0x3d16c8){const _0x423bfe=_0x3d16c8['sourceCode'],_0x23309c=/@see\s+{@link\s+([^}\s]+)\s*}/;return {'TSPropertySignature'(_0x24ea3c){const _0x2fcda6=_0x24ea3c['typeAnnotation']?.['typeAnnotation'],_0x427a3d=_0x423bfe['getCommentsBefore'](_0x24ea3c);if(!_0x2fcda6||_0x427a3d['length']===-0x17d6+-0x13b1+0x2b87*0x1||_0x2fcda6['type']!==nodeTypes['TSTypeReference']||!isIdentifier(_0x2fcda6['typeName']))return;const _0x1c8562=_0x2fcda6['typeName']['name'];_0x427a3d['filter'](_0x536754=>_0x536754['type']===nodeTypes['Block']&&_0x536754['value']['startsWith']('*'))['forEach'](_0x560e10=>{const _0x40c281=_0x23309c['exec'](_0x560e10['value']);_0x40c281&&_0x40c281[0x5*-0x65b+0x6*0x1b6+-0x1cb*-0xc]===_0x1c8562&&_0x3d16c8['report']({'node':_0x560e10,'messageId':ruleName,'fix'(_0x3458d3){const _0x1070d4=getFixInstruction(_0x560e10,_0x40c281,_0x423bfe);let _0x1f5aeb=[];return _0x1070d4['type']===constants['fixTypes']['replace']&&(_0x1f5aeb=[_0x3458d3['replaceText'](_0x560e10,_0x1070d4['text'])]),_0x1070d4['type']===constants['fixTypes']['removeRange']&&(_0x1f5aeb=[_0x3458d3['removeRange']([_0x1070d4['range'][0x17*-0xb3+-0xb*-0x13d+0x276],_0x1070d4['range'][-0x8a7+-0x3*-0x5f8+-0x940]])]),_0x1f5aeb;}});});}};},'create'),{'fixable':'code'});const constants={'patterns':{'seeLink':/@see{@link[^}]+}/},'fixTypes':{'removeRange':'removeRange','replace':'replace'}};function createRemoveRangeFix(_0x4b6f15,_0x5d5a07){const _0x18e1cd=[_0x4b6f15,_0x5d5a07];return {'type':constants['fixTypes']['removeRange'],'range':_0x18e1cd};}__name(createRemoveRangeFix,'createRemoveRangeFix');function createReplaceFix(_0x179e24){return {'type':constants['fixTypes']['replace'],'text':_0x179e24};}__name(createReplaceFix,'createReplaceFix');function getStandaloneFix(_0xece3a8,_0x698e52){const _0x514007=_0x698e52['getIndexFromLoc']({'line':_0xece3a8['loc']['start']['line'],'column':0x0});let _0x38c3e0=_0xece3a8['range'][0x79*-0x3+0x1a07+-0x189b];return _0x698e52['text']['charAt'](_0x38c3e0)==='\x0a'&&(_0x38c3e0+=0x1*0x76d+0xdf1*-0x1+0x685),createRemoveRangeFix(_0x514007,_0x38c3e0);}__name(getStandaloneFix,'getStandaloneFix');function getMultilineFix(_0x49634b,_0xed29ae,_0x32b7e8){const _0xbc151=_0x49634b['split']('\x0a'),_0x16364d=_0xbc151['findIndex'](_0x1b848a=>_0x1b848a['includes'](_0xed29ae));let _0x494bfb;if(_0x16364d!==-(-0xa0+-0x1621+0x1*0x16c2)){const _0x56802c=_0xbc151[_0x16364d],_0x29ca07=_0x32b7e8(_0x56802c)['replace'](constants['patterns']['seeLink'],'');if(!_0x29ca07){_0xbc151['splice'](_0x16364d,0x1f59+-0x210f+0x1b7);const _0x1c6475=_0xbc151['filter']((_0xc45f96,_0x1e1983)=>{const _0x2b03bf=_0x1e1983===-0x3d*0x1d+-0x1*-0xb17+0xd6*-0x5||_0x1e1983===_0xbc151['length']-(-0x1d35+0x4ec*-0x2+0x270e);if(_0x2b03bf)return !![];return _0xc45f96['trim']()!=='*';});_0x494bfb=createReplaceFix(_0x1c6475['join']('\x0a'));}}return _0x494bfb;}__name(getMultilineFix,'getMultilineFix');function getInlineFix(_0x37fdf3,_0x57cd0a,_0x3b9609){const _0x56aaa4=_0x57cd0a['indexOf'](_0x3b9609),_0x445261=_0x37fdf3['range'][-0x17*0xa2+0xece+-0x40]+_0x56aaa4,_0x512a99=_0x445261+_0x3b9609['length'],_0x538374=createRemoveRangeFix(_0x445261,_0x512a99);return _0x538374;}__name(getInlineFix,'getInlineFix');function getFixInstruction(_0x2dc2fe,_0x2f3954,_0x1b8b3e){const _0x2b4f8e=_0x1b8b3e['getText'](_0x2dc2fe),_0x2d912c=_0x2f3954[-0x2a1*-0x1+0x1*0x1397+0x13c*-0x12],_0x95af78=__name(_0x8945df=>_0x8945df['replace'](/[/*\s]/g,''),'stripCommentDecorations'),_0x762d4e=_0x95af78(_0x2b4f8e)['replace'](constants['patterns']['seeLink'],'');let _0x5b7e27=getInlineFix(_0x2dc2fe,_0x2b4f8e,_0x2d912c);!_0x762d4e&&(_0x5b7e27=getStandaloneFix(_0x2dc2fe,_0x1b8b3e));if(_0x762d4e&&_0x2b4f8e['includes']('\x0a')){const _0x3ebb29=getMultilineFix(_0x2b4f8e,_0x2d912c,_0x95af78);_0x3ebb29&&(_0x5b7e27=_0x3ebb29);}return _0x5b7e27;}__name(getFixInstruction,'getFixInstruction');
5
+ var __defProp=Object['defineProperty'],__name=(_0x446dea,_0x43c478)=>__defProp(_0x446dea,'name',{'value':_0x43c478,'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(_0x1c33e3){const _0x46083a=_0x1c33e3['sourceCode'],_0x17900b=/@see\s+{@link\s+([^}\s]+)\s*}/;return {'TSPropertySignature'(_0x4646e6){const _0x491a7d=_0x4646e6['typeAnnotation']?.['typeAnnotation'],_0x591ed3=_0x46083a['getCommentsBefore'](_0x4646e6);if(!_0x491a7d||_0x591ed3['length']===0x377*0x2+-0x35*0x4a+0x864||_0x491a7d['type']!==nodeTypes['TSTypeReference']||!isIdentifier(_0x491a7d['typeName']))return;const _0x24a239=_0x491a7d['typeName']['name'];_0x591ed3['filter'](_0x5683bc=>_0x5683bc['type']===nodeTypes['Block']&&_0x5683bc['value']['startsWith']('*'))['forEach'](_0x592451=>{const _0x320d37=_0x17900b['exec'](_0x592451['value']);_0x320d37&&_0x320d37[0x2*-0x122e+-0xe5*0x2b+0x4ad4]===_0x24a239&&_0x1c33e3['report']({'node':_0x592451,'messageId':ruleName,'fix'(_0x58c7db){const _0x2b1ee3=getFixInstruction(_0x592451,_0x320d37,_0x46083a);let _0x204676=[];return _0x2b1ee3['type']===constants['fixTypes']['replace']&&(_0x204676=[_0x58c7db['replaceText'](_0x592451,_0x2b1ee3['text'])]),_0x2b1ee3['type']===constants['fixTypes']['removeRange']&&(_0x204676=[_0x58c7db['removeRange']([_0x2b1ee3['range'][-0x13*0x115+0x215f+-0xcd0],_0x2b1ee3['range'][-0x127f*0x1+-0xc7d*0x2+0x5*0x8b2]])]),_0x204676;}});});}};},'create'),{'fixable':'code'});const constants={'patterns':{'seeLink':/@see{@link[^}]+}/},'fixTypes':{'removeRange':'removeRange','replace':'replace'}};function createRemoveRangeFix(_0x6b23ab,_0x4b0f37){const _0x37a7d1=[_0x6b23ab,_0x4b0f37];return {'type':constants['fixTypes']['removeRange'],'range':_0x37a7d1};}__name(createRemoveRangeFix,'createRemoveRangeFix');function createReplaceFix(_0x4dcb26){return {'type':constants['fixTypes']['replace'],'text':_0x4dcb26};}__name(createReplaceFix,'createReplaceFix');function getStandaloneFix(_0x36e9d8,_0x36145a){const _0x107d55=_0x36145a['getIndexFromLoc']({'line':_0x36e9d8['loc']['start']['line'],'column':0x0});let _0x2c0f66=_0x36e9d8['range'][0x2681+-0xf5b*0x2+-0x3e5*0x2];return _0x36145a['text']['charAt'](_0x2c0f66)==='\x0a'&&(_0x2c0f66+=0x818+0x7ff+-0x1016),createRemoveRangeFix(_0x107d55,_0x2c0f66);}__name(getStandaloneFix,'getStandaloneFix');function getMultilineFix(_0x5d5ec0,_0x111a71,_0x4a4f9f){const _0x583fb5=_0x5d5ec0['split']('\x0a'),_0xf31384=_0x583fb5['findIndex'](_0x4a1e1a=>_0x4a1e1a['includes'](_0x111a71));let _0x563124;if(_0xf31384!==-(-0x1f9f+0xfe+0xf51*0x2)){const _0x1b2b11=_0x583fb5[_0xf31384],_0x11da33=_0x4a4f9f(_0x1b2b11)['replace'](constants['patterns']['seeLink'],'');if(!_0x11da33){_0x583fb5['splice'](_0xf31384,0x68f+0x1f0c+-0x259a);const _0x416d37=_0x583fb5['filter']((_0x5fdb46,_0x493a92)=>{const _0x423f58=_0x493a92===0x107*-0x16+0x9*-0x1c9+0x26ab*0x1||_0x493a92===_0x583fb5['length']-(-0x1c37*0x1+-0x56e*-0x2+0x16*0xca);if(_0x423f58)return !![];return _0x5fdb46['trim']()!=='*';});_0x563124=createReplaceFix(_0x416d37['join']('\x0a'));}}return _0x563124;}__name(getMultilineFix,'getMultilineFix');function getInlineFix(_0x4ea303,_0x564fa7,_0x40ab40){const _0x539433=_0x564fa7['indexOf'](_0x40ab40),_0x38921a=_0x4ea303['range'][-0x2045+0x1*-0x5ef+-0x2*-0x131a]+_0x539433,_0x505945=_0x38921a+_0x40ab40['length'],_0x3cc3b3=createRemoveRangeFix(_0x38921a,_0x505945);return _0x3cc3b3;}__name(getInlineFix,'getInlineFix');function getFixInstruction(_0x4c79d2,_0x271fc7,_0x5eef7d){const _0x3449c5=_0x5eef7d['getText'](_0x4c79d2),_0x4f8a96=_0x271fc7[-0x2479+0x1*0x53+-0x7*-0x52a],_0x1c57f1=__name(_0x2ed3e7=>_0x2ed3e7['replace'](/[/*\s]/g,''),'stripCommentDecorations'),_0x33a337=_0x1c57f1(_0x3449c5)['replace'](constants['patterns']['seeLink'],'');let _0x7ddcf0=getInlineFix(_0x4c79d2,_0x3449c5,_0x4f8a96);!_0x33a337&&(_0x7ddcf0=getStandaloneFix(_0x4c79d2,_0x5eef7d));if(_0x33a337&&_0x3449c5['includes']('\x0a')){const _0xce5412=getMultilineFix(_0x3449c5,_0x4f8a96,_0x1c57f1);_0xce5412&&(_0x7ddcf0=_0xce5412);}return _0x7ddcf0;}__name(getFixInstruction,'getFixInstruction');
7
6
 
8
7
  export { mustNotUseSeeLinkInDocsIfTypeAvailable as default, ruleName };
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
- import { isNameMatch, isMemberExpression, isIdentifier } from '@flint/infra/ast-helpers';
3
- import { createEslintRule } from '@flint/infra/utils/create-eslint-rule';
2
+ import { isNameMatch, isMemberExpression, isIdentifier } from '@flint/infra/analysis';
3
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
4
4
 
5
- var __defProp=Object['defineProperty'],__name=(_0x3e2fc9,_0x1c3d0c)=>__defProp(_0x3e2fc9,'name',{'value':_0x1c3d0c,'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(_0x39bc2c){let _0xb66560=0x238d+0x1db3*0x1+-0x4140;return {'CallExpression'(_0x48828a){const _0x3ea8bb=_0x48828a['callee'];(isDirectRunTests(_0x3ea8bb)||isTesterRun(_0x3ea8bb))&&(_0xb66560++,_0xb66560>0x1491+0x1f39*-0x1+0x1*0xaa9&&_0x39bc2c['report']({'node':_0x48828a,'messageId':ruleName}));}};},'create'));function isDirectRunTests(_0x373d6b){return isNameMatch(_0x373d6b,'runTests')||isNameMatch(_0x373d6b,'runEslintTests');}__name(isDirectRunTests,'isDirectRunTests');function isTesterRun(_0x37c6d2){return isMemberExpression(_0x37c6d2)&&isIdentifier(_0x37c6d2['object'])&&_0x37c6d2['object']['name']['toLowerCase']()['includes']('tester')&&isNameMatch(_0x37c6d2['property'],'run');}__name(isTesterRun,'isTesterRun');
5
+ var __defProp=Object['defineProperty'],__name=(_0x14c3a2,_0xd6c47d)=>__defProp(_0x14c3a2,'name',{'value':_0xd6c47d,'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(_0x3e4c3b){let _0x4ad342=0x135a*0x1+-0x1a2*0x13+0xbac;return {'CallExpression'(_0x3de75f){const _0x485bca=_0x3de75f['callee'];(isDirectRunTests(_0x485bca)||isTesterRun(_0x485bca))&&(_0x4ad342++,_0x4ad342>-0x630+0x2*-0x97+0x75f&&_0x3e4c3b['report']({'node':_0x3de75f,'messageId':ruleName}));}};},'create'));function isDirectRunTests(_0x3b7b9f){return isNameMatch(_0x3b7b9f,'runTests')||isNameMatch(_0x3b7b9f,'runEslintTests');}__name(isDirectRunTests,'isDirectRunTests');function isTesterRun(_0x4f9f1f){return isMemberExpression(_0x4f9f1f)&&isIdentifier(_0x4f9f1f['object'])&&_0x4f9f1f['object']['name']['toLowerCase']()['includes']('tester')&&isNameMatch(_0x4f9f1f['property'],'run');}__name(isTesterRun,'isTesterRun');
6
6
 
7
7
  export { mustSeparateUnrelatedTestsIntoDifferentFiles as default, ruleName };
@@ -0,0 +1,4 @@
1
+ export declare const ruleName = "must-specify-second-generic-parameter-in-apipost-and-apiput";
2
+ export declare const ruleContent = "\n### **Must** specify second generic parameter in apiPost and apiPut\n\n#### Wrong\n\nconst foo = apiPost<bar>(baz, qux) {}\n\n#### Correct\n\nconst foo = apiPost<bar, baz>(baz, qux) {}\n\n#### Why\n\nAdds an additional level of type checking to prevent further errors and type inconsistencies.";
3
+ declare const _default: any;
4
+ export default _default;
@@ -0,0 +1,7 @@
1
+ 'use strict';
2
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
3
+ import { isNameMatch, isIdentifier } from '@flint/infra/analysis';
4
+
5
+ var __defProp=Object['defineProperty'],__name=(_0x3d0ee7,_0x341601)=>__defProp(_0x3d0ee7,'name',{'value':_0x341601,'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(_0x1d7197){return {'CallExpression'(_0x5ec728){const _0x1edfff=isNameMatch(_0x5ec728['callee'],'apiPost')&&!hasCorrectCountOfGenericParameters(_0x5ec728),_0x29cafe=isNameMatch(_0x5ec728['callee'],'apiPut')&&!hasCorrectCountOfGenericParameters(_0x5ec728);isIdentifier(_0x5ec728['callee'])&&(_0x1edfff||_0x29cafe)&&_0x1d7197['report']({'node':_0x5ec728,'messageId':ruleName});}};},'create'));function hasCorrectCountOfGenericParameters(_0x22b99d){return _0x22b99d['typeArguments']&&(_0x22b99d['arguments']['length']===0x950+-0x10bb+0x76c&&_0x22b99d['typeArguments']['params']['length']===0x15f6+-0x9*0x1eb+-0x4b2||_0x22b99d['arguments']['length']>=-0xce*0xa+0x1ab*-0x14+-0x117*-0x26&&_0x22b99d['typeArguments']['params']['length']===-0x466*0x4+0x2707+-0x156d);}__name(hasCorrectCountOfGenericParameters,'hasCorrectCountOfGenericParameters');
6
+
7
+ export { mustSpecifySecondGenericParameterInApipostAndApiput as default, ruleContent, ruleName };
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
- import { createEslintRule } from '@flint/infra/utils/create-eslint-rule';
3
- import { nodeTypes, iterateDescendants, isStringLiteral } from '@flint/infra/ast-helpers';
2
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
3
+ import { nodeTypes, iterateDescendants, isStringLiteral } from '@flint/infra/analysis';
4
4
 
5
- var __defProp=Object['defineProperty'],__name=(_0x29c565,_0x8c6dad)=>__defProp(_0x29c565,'name',{'value':_0x8c6dad,'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(_0x5377f1){const _0x211674=_0x5377f1['sourceCode'];return {'JSXAttribute'(_0xf2e12d){if(_0xf2e12d['name']['type']!==nodeTypes['JSXIdentifier']||_0xf2e12d['name']['name']!==attributeName||!_0xf2e12d['value'])return;handleNode(_0x5377f1,_0xf2e12d['value']);for(const _0x46e1ef of iterateDescendants(_0xf2e12d['value'],_0x211674['visitorKeys'])){handleNode(_0x5377f1,_0x46e1ef['value']);}}};},'create'));function handleNode(_0x11be42,_0x235fee){if(isStringLiteral(_0x235fee))handleClassNames(_0x11be42,_0x235fee,_0x235fee['value']);else _0x235fee['type']===nodeTypes['templateLiteral']&&handleClassNames(_0x11be42,_0x235fee,buildMaskedTemplateLiteral(_0x235fee));}__name(handleNode,'handleNode');function handleClassNames(_0x2cc67a,_0x4efef9,_0x46cb7f){const _0x5df29f=_0x2cc67a['sourceCode'];for(const _0x3ffb76 of _0x46cb7f['matchAll'](regexes['classWithArbitraryValue'])){const _0x11911a=_0x3ffb76[-0xb*0x175+0xb51*-0x2+-0xe*-0x2c3],_0xe933d=_0x11911a['slice'](0x1028+-0x2*-0xc05+-0x2831,-(0x43*-0x47+-0x967+0x1bfd));if(colorNames['has'](_0xe933d)||Object['values'](regexes)['some'](_0x1bc4d9=>_0x1bc4d9['test'](_0xe933d))){const _0x143388=_0x3ffb76[0x1dba+-0x1899+-0xd*0x65],_0x2b932a=_0x4efef9['range'][-0x74a+-0x10cb*0x1+0x1*0x1815]+(-0x2b*0x7+-0x1cf9*0x1+-0x1e27*-0x1)+_0x3ffb76['index']+_0x143388['indexOf'](_0x11911a),_0x4dc156=_0x5df29f['getLocFromIndex'](_0x2b932a),_0xc73abe=_0x5df29f['getLocFromIndex'](_0x2b932a+_0x11911a['length']);_0x2cc67a['report']({'node':_0x4efef9,'messageId':ruleName,'loc':{'start':_0x4dc156,'end':_0xc73abe}});}}}__name(handleClassNames,'handleClassNames');const attributeName='className',colorNames=new Set(['aliceblue','antiquewhite','aqua','aquamarine','azure','beige','bisque','black','blanchedalmond','blue','blueviolet','brown','burlywood','cadetblue','chartreuse','chocolate','coral','cornflowerblue','cornsilk','crimson','cyan','darkblue','darkcyan','darkgoldenrod','darkgray','darkgreen','darkgrey','darkkhaki','darkmagenta','darkolivegreen','darkorange','darkorchid','darkred','darksalmon','darkseagreen','darkslateblue','darkslategray','darkslategrey','darkturquoise','darkviolet','deeppink','deepskyblue','dimgray','dimgrey','dodgerblue','firebrick','floralwhite','forestgreen','fuchsia','gainsboro','ghostwhite','gold','goldenrod','gray','green','greenyellow','grey','honeydew','hotpink','indianred','indigo','ivory','khaki','lavender','lavenderblush','lawngreen','lemonchiffon','lightblue','lightcoral','lightcyan','lightgoldenrodyellow','lightgray','lightgreen','lightgrey','lightpink','lightsalmon','lightseagreen','lightskyblue','lightslategray','lightslategrey','lightsteelblue','lightyellow','lime','limegreen','linen','magenta','maroon','mediumaquamarine','mediumblue','mediumorchid','mediumpurple','mediumseagreen','mediumslateblue','mediumspringgreen','mediumturquoise','mediumvioletred','midnightblue','mintcream','mistyrose','moccasin','navajowhite','navy','oldlace','olive','olivedrab','orange','orangered','orchid','palegoldenrod','palegreen','paleturquoise','palevioletred','papayawhip','peachpuff','peru','pink','plum','powderblue','purple','rebeccapurple','red','rosybrown','royalblue','saddlebrown','salmon','sandybrown','seagreen','seashell','sienna','silver','skyblue','slateblue','slategray','slategrey','snow','springgreen','steelblue','tan','teal','thistle','tomato','transparent','turquoise','violet','wheat','white','whitesmoke','yellow','yellowgreen']),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(_0x360d2f){return _0x360d2f['quasis']['map']((_0x208881,_0x5e7e73)=>{const _0x20586c=_0x360d2f['expressions'][_0x5e7e73];return [_0x208881['value']['raw'],_0x20586c?'${'+'\x20'['repeat'](_0x20586c['range'][-0x11d1+0x198f+0x11b*-0x7]-_0x20586c['range'][-0x1*-0x117a+0x82a+-0x19a4])+'}':'']['join']('');})['join']('');}__name(buildMaskedTemplateLiteral,'buildMaskedTemplateLiteral');
5
+ var __defProp=Object['defineProperty'],__name=(_0x484cad,_0x5cfcf8)=>__defProp(_0x484cad,'name',{'value':_0x5cfcf8,'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(_0x54c118){const _0x13fffc=_0x54c118['sourceCode'];return {'JSXAttribute'(_0x894155){if(_0x894155['name']['type']!==nodeTypes['JSXIdentifier']||_0x894155['name']['name']!==attributeName||!_0x894155['value'])return;handleNode(_0x54c118,_0x894155['value']);for(const _0x2987d2 of iterateDescendants(_0x894155['value'],_0x13fffc['visitorKeys'])){handleNode(_0x54c118,_0x2987d2['value']);}}};},'create'));function handleNode(_0x15c3e9,_0x522d52){if(isStringLiteral(_0x522d52))handleClassNames(_0x15c3e9,_0x522d52,_0x522d52['value']);else _0x522d52['type']===nodeTypes['templateLiteral']&&handleClassNames(_0x15c3e9,_0x522d52,buildMaskedTemplateLiteral(_0x522d52));}__name(handleNode,'handleNode');function handleClassNames(_0x4d5e9d,_0x817446,_0x3caf82){const _0x5d5e03=_0x4d5e9d['sourceCode'];for(const _0x4cc70d of _0x3caf82['matchAll'](regexes['classWithArbitraryValue'])){const _0x33a3b9=_0x4cc70d[-0x188b+0x1*-0x2311+0x3b9d],_0x3feb35=_0x33a3b9['slice'](0x13d2+0x57b*0x5+0x8*-0x5e7,-(0x2ef*-0x1+0xa04*0x2+0x1*-0x1118));if(colorNames['has'](_0x3feb35)||Object['values'](regexes)['some'](_0x555d82=>_0x555d82['test'](_0x3feb35))){const _0x1d0847=_0x4cc70d[-0x1740+0x1933*0x1+-0x1f3],_0x4053c6=_0x817446['range'][-0x27d*-0xf+0x175f*-0x1+-0xdf4]+(-0x890+0x3*0x50b+0x1*-0x690)+_0x4cc70d['index']+_0x1d0847['indexOf'](_0x33a3b9),_0x53409=_0x5d5e03['getLocFromIndex'](_0x4053c6),_0x507531=_0x5d5e03['getLocFromIndex'](_0x4053c6+_0x33a3b9['length']);_0x4d5e9d['report']({'node':_0x817446,'messageId':ruleName,'loc':{'start':_0x53409,'end':_0x507531}});}}}__name(handleClassNames,'handleClassNames');const attributeName='className',colorNames=new Set(['aliceblue','antiquewhite','aqua','aquamarine','azure','beige','bisque','black','blanchedalmond','blue','blueviolet','brown','burlywood','cadetblue','chartreuse','chocolate','coral','cornflowerblue','cornsilk','crimson','cyan','darkblue','darkcyan','darkgoldenrod','darkgray','darkgreen','darkgrey','darkkhaki','darkmagenta','darkolivegreen','darkorange','darkorchid','darkred','darksalmon','darkseagreen','darkslateblue','darkslategray','darkslategrey','darkturquoise','darkviolet','deeppink','deepskyblue','dimgray','dimgrey','dodgerblue','firebrick','floralwhite','forestgreen','fuchsia','gainsboro','ghostwhite','gold','goldenrod','gray','green','greenyellow','grey','honeydew','hotpink','indianred','indigo','ivory','khaki','lavender','lavenderblush','lawngreen','lemonchiffon','lightblue','lightcoral','lightcyan','lightgoldenrodyellow','lightgray','lightgreen','lightgrey','lightpink','lightsalmon','lightseagreen','lightskyblue','lightslategray','lightslategrey','lightsteelblue','lightyellow','lime','limegreen','linen','magenta','maroon','mediumaquamarine','mediumblue','mediumorchid','mediumpurple','mediumseagreen','mediumslateblue','mediumspringgreen','mediumturquoise','mediumvioletred','midnightblue','mintcream','mistyrose','moccasin','navajowhite','navy','oldlace','olive','olivedrab','orange','orangered','orchid','palegoldenrod','palegreen','paleturquoise','palevioletred','papayawhip','peachpuff','peru','pink','plum','powderblue','purple','rebeccapurple','red','rosybrown','royalblue','saddlebrown','salmon','sandybrown','seagreen','seashell','sienna','silver','skyblue','slateblue','slategray','slategrey','snow','springgreen','steelblue','tan','teal','thistle','tomato','transparent','turquoise','violet','wheat','white','whitesmoke','yellow','yellowgreen']),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(_0x20f3a3){return _0x20f3a3['quasis']['map']((_0x2fdc91,_0x51af42)=>{const _0x41ddd9=_0x20f3a3['expressions'][_0x51af42];return [_0x2fdc91['value']['raw'],_0x41ddd9?'${'+'\x20'['repeat'](_0x41ddd9['range'][0x19ca+-0x3*-0x18d+0x4*-0x79c]-_0x41ddd9['range'][-0x1d1+0x2627+0x2*-0x122b])+'}':'']['join']('');})['join']('');}__name(buildMaskedTemplateLiteral,'buildMaskedTemplateLiteral');
6
6
 
7
7
  export { mustUseColorVariablesInsteadOfHardcodedValues as default, ruleName };
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
- import { createEslintRule } from '@flint/infra/utils/create-eslint-rule';
3
- import { isJSXIdentifier, isJSXExpressionContainer, isTemplateLiteral, isStringLikeTypeNode, nodeTypes, isMemberCallExpression, isArrayMethodCallExpression } from '@flint/infra/ast-helpers';
2
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
3
+ import { isJSXIdentifier, isJSXExpressionContainer, isTemplateLiteral, isStringLikeTypeNode, nodeTypes, isMemberCallExpression, isArrayMethodCallExpression } from '@flint/infra/analysis';
4
4
  import { ESLintUtils } from '@typescript-eslint/utils';
5
5
 
6
- var __defProp=Object['defineProperty'],__name=(_0x254e31,_0x3e2e13)=>__defProp(_0x254e31,'name',{'value':_0x3e2e13,'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(_0x5c4586){const _0x3f96a8=ESLintUtils['getParserServices'](_0x5c4586);return {'JSXAttribute'(_0x2f2de3){if(!isJSXIdentifier(_0x2f2de3['name'])||_0x2f2de3['name']['name']!==attributeName||!_0x2f2de3['value']||!isJSXExpressionContainer(_0x2f2de3['value']))return;const _0x5da258=_0x2f2de3['value']['expression'];(isConcatenationUsingOperator(_0x5da258,_0x3f96a8)||isTemplateLiteral(_0x5da258)&&_0x5da258['expressions']['length']>0x215e+0x17*0x101+-0x3875||isConcatenationUsingStringMethod(_0x5da258,_0x3f96a8)||isConcatenationUsingArrayMethod(_0x5da258,_0x3f96a8)||isPossibleConcatenationUsingArrayMethod(_0x5da258,_0x3f96a8))&&_0x5c4586['report']({'node':_0x2f2de3,'messageId':ruleName});}};},'create'));const attributeName='id',concatenationMethods={'string':['concat'],'array':{'definitely':['join'],'possibly':['reduce','reduceRight']}};function isConcatenationUsingOperator(_0x5c70e6,_0x3e79b7){return _0x5c70e6['type']===nodeTypes['binaryExpression']&&_0x5c70e6['operator']==='+'&&isStringLikeTypeNode(_0x5c70e6,_0x3e79b7);}__name(isConcatenationUsingOperator,'isConcatenationUsingOperator');function isConcatenationUsingStringMethod(_0x48270e,_0x305583){return isMemberCallExpression(_0x48270e)&&isStringLikeTypeNode(_0x48270e['callee']['object'],_0x305583)&&!_0x48270e['callee']['computed']&&concatenationMethods['string']['includes'](_0x48270e['callee']['property']['name']);}__name(isConcatenationUsingStringMethod,'isConcatenationUsingStringMethod');function isConcatenationUsingArrayMethod(_0x589bef,_0x5773d4){return isArrayMethodCallExpression(_0x589bef,_0x5773d4,concatenationMethods['array']['definitely']);}__name(isConcatenationUsingArrayMethod,'isConcatenationUsingArrayMethod');function isPossibleConcatenationUsingArrayMethod(_0x3a577c,_0x1e84a7){return isArrayMethodCallExpression(_0x3a577c,_0x1e84a7,concatenationMethods['array']['possibly'])&&isStringLikeTypeNode(_0x3a577c,_0x1e84a7);}__name(isPossibleConcatenationUsingArrayMethod,'isPossibleConcatenationUsingArrayMethod');
6
+ var __defProp=Object['defineProperty'],__name=(_0x374aaa,_0x3e0823)=>__defProp(_0x374aaa,'name',{'value':_0x3e0823,'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(_0x174674){const _0x345f57=ESLintUtils['getParserServices'](_0x174674);return {'JSXAttribute'(_0x35221c){if(!isJSXIdentifier(_0x35221c['name'])||_0x35221c['name']['name']!==attributeName||!_0x35221c['value']||!isJSXExpressionContainer(_0x35221c['value']))return;const _0x1b029d=_0x35221c['value']['expression'];(isConcatenationUsingOperator(_0x1b029d,_0x345f57)||isTemplateLiteral(_0x1b029d)&&_0x1b029d['expressions']['length']>0xa*-0x71+0x1*-0x4d7+0x1*0x941||isConcatenationUsingStringMethod(_0x1b029d,_0x345f57)||isConcatenationUsingArrayMethod(_0x1b029d,_0x345f57)||isPossibleConcatenationUsingArrayMethod(_0x1b029d,_0x345f57))&&_0x174674['report']({'node':_0x35221c,'messageId':ruleName});}};},'create'));const attributeName='id',concatenationMethods={'string':['concat'],'array':{'definitely':['join'],'possibly':['reduce','reduceRight']}};function isConcatenationUsingOperator(_0x8bcfe3,_0x37c849){return _0x8bcfe3['type']===nodeTypes['binaryExpression']&&_0x8bcfe3['operator']==='+'&&isStringLikeTypeNode(_0x8bcfe3,_0x37c849);}__name(isConcatenationUsingOperator,'isConcatenationUsingOperator');function isConcatenationUsingStringMethod(_0x196fe4,_0x167d41){return isMemberCallExpression(_0x196fe4)&&isStringLikeTypeNode(_0x196fe4['callee']['object'],_0x167d41)&&!_0x196fe4['callee']['computed']&&concatenationMethods['string']['includes'](_0x196fe4['callee']['property']['name']);}__name(isConcatenationUsingStringMethod,'isConcatenationUsingStringMethod');function isConcatenationUsingArrayMethod(_0x487a52,_0x42d792){return isArrayMethodCallExpression(_0x487a52,_0x42d792,concatenationMethods['array']['definitely']);}__name(isConcatenationUsingArrayMethod,'isConcatenationUsingArrayMethod');function isPossibleConcatenationUsingArrayMethod(_0x27bb7b,_0x1992f2){return isArrayMethodCallExpression(_0x27bb7b,_0x1992f2,concatenationMethods['array']['possibly'])&&isStringLikeTypeNode(_0x27bb7b,_0x1992f2);}__name(isPossibleConcatenationUsingArrayMethod,'isPossibleConcatenationUsingArrayMethod');
7
7
 
8
8
  export { mustUseFunctionsForComponentIds as default, ruleName };
@@ -0,0 +1,3 @@
1
+ export declare const ruleName = "must-use-odata-builder";
2
+ declare const _default: any;
3
+ export default _default;
@@ -0,0 +1,7 @@
1
+ 'use strict';
2
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
3
+ import { isMemberExpression, isIdentifier, isCallExpression } from '@flint/infra/analysis';
4
+
5
+ var __defProp=Object['defineProperty'],__name=(_0x1876ad,_0x4f888f)=>__defProp(_0x1876ad,'name',{'value':_0x4f888f,'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(_0x4f4dbe){const _0x53b59f=new Set();return {'VariableDeclarator'(_0x420dc5){if(!isIdentifier(_0x420dc5['id']))return;const _0x8f076a=_0x420dc5['init'];if(!_0x8f076a||!isCallExpression(_0x8f076a))return;const _0x26f749=_0x8f076a['callee'];if(!isIdentifier(_0x26f749)||_0x26f749['name']!=='getEmptyODataConfig')return;_0x53b59f['add'](_0x420dc5['id']['name']),_0x4f4dbe['report']({'node':_0x420dc5,'messageId':ruleName});},'CallExpression'(_0x3828db){if(!isMemberExpression(_0x3828db['callee']))return;const _0x315ef3=_0x3828db['callee']['object'];if(!isMemberExpression(_0x315ef3))return;const _0x28df1d=_0x315ef3['object'],_0x495c7f=_0x315ef3['property'];if(!isIdentifier(_0x28df1d)||!isIdentifier(_0x495c7f))return;_0x53b59f['has'](_0x28df1d['name'])&&_0x495c7f['name']==='filters'&&isIdentifier(_0x3828db['callee']['property'])&&_0x3828db['callee']['property']['name']==='push'&&_0x4f4dbe['report']({'node':_0x3828db,'messageId':ruleName});}};},'create'));
6
+
7
+ export { mustUseOdataBuilder as default, ruleName };
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
- import { createEslintRule } from '@flint/infra/utils/create-eslint-rule';
3
- import { isIdentifier, isMemberExpression } from '@flint/infra/ast-helpers';
2
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
3
+ import { isIdentifier, isMemberExpression } from '@flint/infra/analysis';
4
4
 
5
- var __defProp=Object['defineProperty'],__name=(_0xb14a14,_0x24a695)=>__defProp(_0xb14a14,'name',{'value':_0x24a695,'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.';var mustUseOnlyCrudOperations = createEslintRule(ruleName,ruleContent,__name(function create(_0x196fe9){const _0x4e5483=_0x196fe9['options'][0x1*0x68f+0x2*-0x684+0x1*0x679]??{'restrictedFunctions':['createResource']},_0x22a81f=_0x4e5483['restrictedFunctions'];return {'CallExpression'(_0x2f8fc8){const _0x614581=_0x2f8fc8['callee'];let _0x163de6;if(isIdentifier(_0x614581))_0x163de6=_0x614581['name'];else isMemberExpression(_0x614581)&&isIdentifier(_0x614581['property'])&&(_0x163de6=_0x614581['property']['name']);_0x163de6!==void(0xc61*-0x1+-0x160b+-0x1136*-0x2)&&_0x22a81f['includes'](_0x163de6)&&_0x196fe9['report']({'node':_0x2f8fc8,'messageId':ruleName});}};},'create'),{'schema':[{'type':'object','properties':{'restrictedFunctions':{'type':'array','items':{'type':'string'}}},'additionalProperties':![]}],'defaultOptions':[{'restrictedFunctions':['createResource']}]});
5
+ var __defProp=Object['defineProperty'],__name=(_0x592b55,_0x8e378a)=>__defProp(_0x592b55,'name',{'value':_0x8e378a,'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.';var mustUseOnlyCrudOperations = createEslintRule(ruleName,ruleContent,__name(function create(_0x5c1533){const _0x4efd3a=_0x5c1533['options'][0x25f*0xa+0x4*0x5ce+-0x2eee]??{'restrictedFunctions':['createResource']},_0x59d387=_0x4efd3a['restrictedFunctions'];return {'CallExpression'(_0x3dfc12){const _0x2076ff=_0x3dfc12['callee'];let _0x3293b9;if(isIdentifier(_0x2076ff))_0x3293b9=_0x2076ff['name'];else isMemberExpression(_0x2076ff)&&isIdentifier(_0x2076ff['property'])&&(_0x3293b9=_0x2076ff['property']['name']);_0x3293b9!==void(-0x13ee+-0x565*-0x5+0x70b*-0x1)&&_0x59d387['includes'](_0x3293b9)&&_0x5c1533['report']({'node':_0x3dfc12,'messageId':ruleName});}};},'create'),{'schema':[{'type':'object','properties':{'restrictedFunctions':{'type':'array','items':{'type':'string'}}},'additionalProperties':![]}],'defaultOptions':[{'restrictedFunctions':['createResource']}]});
6
6
 
7
7
  export { mustUseOnlyCrudOperations as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "filename-kebab-case";
2
3
  declare const filenameKebabCase: ESLintUtils.RuleModule<"useKebabCase", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default filenameKebabCase;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { getFileName } from '@flint/infra/ast-helpers';
3
+ import { getFileName } from '@flint/infra/analysis';
4
+ import { url, ruleTypes } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0x5e9d22,_0x23d0c7)=>__defProp(_0x5e9d22,'name',{'value':_0x23d0c7,'configurable':!![]});const url='https://example.com/rules/',createRule=ESLintUtils['RuleCreator'](_0x61a39c=>''+url+_0x61a39c),virtualFilename='input-file',ignoredFilenames=['README','README.md','LICENSE','Makefile','.env','.gitignore','.eslintrc.js','.prettierrc','.prettierignore'];function isKebabCase(_0x47acc9){let _0x143bcf;if(ignoredFilenames['includes'](_0x47acc9))_0x143bcf=!![];else {const _0x227997=getFileName(_0x47acc9),_0x3c6625=_0x227997['split']('.')[-0x505*-0x2+-0x26c6+0x1cbc];!_0x3c6625?_0x143bcf=![]:_0x143bcf=/^[a-z0-9]+([-.][a-z0-9]+)*(\.[a-z]+)?$/['test'](_0x3c6625);}return _0x143bcf;}__name(isKebabCase,'isKebabCase');const filenameKebabCase=createRule({'name':'filename-kebab-case','meta':{'type':'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\x20\x20\x20\x20\x20\x20\x20\x20\x0a####\x20Wrong:\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0aMyComponent.ts\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0a####\x20Correct:\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0amy-component.ts\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0a####\x20Why:\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0aFilenames\x20should\x20use\x20kebab-case\x20(lowercase\x20and\x20dashes)\x20to\x20maintain\x20consistency\x20through\x20codebase.'},'schema':[]},'create'(_0xa48325){const _0x22c6e6=getFileName(_0xa48325['filename']);return _0x22c6e6!==virtualFilename&&!isKebabCase(_0x22c6e6)&&_0xa48325['report']({'loc':{'line':0x1,'column':0x0},'messageId':'useKebabCase','data':{'fileName':_0x22c6e6}}),{};},'defaultOptions':[]});
6
+ var __defProp=Object['defineProperty'],__name=(_0x1cccb7,_0xcc1205)=>__defProp(_0x1cccb7,'name',{'value':_0xcc1205,'configurable':!![]});const ruleName='filename-kebab-case';const createRule=ESLintUtils['RuleCreator'](_0x4d5fe3=>''+url+_0x4d5fe3),virtualFilename='input-file',ignoredFilenames=['README','README.md','LICENSE','Makefile','.env','.gitignore','.eslintrc.js','.prettierrc','.prettierignore'];function isKebabCase(_0x2695c8){let _0x156b88;if(ignoredFilenames['includes'](_0x2695c8))_0x156b88=!![];else {const _0xc19967=getFileName(_0x2695c8),_0x14612e=_0xc19967['split']('.')[-0x1f57+-0xd5d+0x165a*0x2];!_0x14612e?_0x156b88=![]:_0x156b88=/^[a-z0-9]+([-.][a-z0-9]+)*(\.[a-z]+)?$/['test'](_0x14612e);}return _0x156b88;}__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'(_0x50c785){const _0x39e7f2=getFileName(_0x50c785['filename']);return _0x39e7f2!==virtualFilename&&!isKebabCase(_0x39e7f2)&&_0x50c785['report']({'loc':{'line':0x1,'column':0x0},'messageId':'useKebabCase','data':{'fileName':_0x39e7f2}}),{};},'defaultOptions':[]});
6
7
 
7
- export { filenameKebabCase as default };
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'](_0x945c17=>''+url+_0x945c17),mustAddEmptyLineBeforeAssertActArrange=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x15ef3a){const _0x1dd94e=_0x15ef3a['sourceCode'];return {'Program'(){const _0x1cd007=_0x1dd94e['getAllComments']();_0x1cd007['forEach'](_0x3a539a=>{const _0x3df60d=_0x1dd94e['getTokenBefore'](_0x3a539a,{'includeComments':!![]}),_0x1865e9=constants['aaaRegex']['test'](_0x3a539a['value'])&&_0x3a539a['loc']['start']['line']!==0x188a*0x1+0xc45+0x7*-0x542&&_0x3df60d&&!(_0x3df60d['type']===constants['tokens']['punctuator']&&_0x3df60d['value']===constants['tokens']['openingBrace'])&&_0x3a539a['loc']['start']['line']-_0x3df60d['loc']['end']['line']===-0x1789+0x1953+-0x1*0x1c9;_0x1865e9&&_0x15ef3a['report']({'loc':_0x3a539a['loc'],'messageId':ruleId,'fix'(_0x32e24f){const _0x4779fb=_0x1dd94e['getIndexFromLoc']({'line':_0x3a539a['loc']['start']['line'],'column':0x0});return _0x32e24f['insertTextBeforeRange']([_0x4779fb,_0x4779fb],'\x0a');}});});}};}});
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'](_0x3faff8=>''+url+_0x3faff8),mustAddEmptyLineBeforeAssertActArrange=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x4da6aa){const _0x3c54b5=_0x4da6aa['sourceCode'];return {'Program'(){const _0x5ebef8=_0x3c54b5['getAllComments']();_0x5ebef8['forEach'](_0xc3dceb=>{const _0x943b1a=_0x3c54b5['getTokenBefore'](_0xc3dceb,{'includeComments':!![]}),_0x24ca81=constants['aaaRegex']['test'](_0xc3dceb['value'])&&_0xc3dceb['loc']['start']['line']!==-0x6*0x655+-0xe4e+0x344d&&_0x943b1a&&!(_0x943b1a['type']===constants['tokens']['punctuator']&&_0x943b1a['value']===constants['tokens']['openingBrace'])&&_0xc3dceb['loc']['start']['line']-_0x943b1a['loc']['end']['line']===0xe*0xf6+-0x963*0x2+0x553;_0x24ca81&&_0x4da6aa['report']({'loc':_0xc3dceb['loc'],'messageId':ruleId,'fix'(_0x5cca29){const _0x505920=_0x3c54b5['getIndexFromLoc']({'line':_0xc3dceb['loc']['start']['line'],'column':0x0});return _0x5cca29['insertTextBeforeRange']([_0x505920,_0x505920],'\x0a');}});});}};}});
6
6
 
7
7
  export { mustAddEmptyLineBeforeAssertActArrange as default, ruleId, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-add-prefix-to-po-functions";
2
3
  declare const mustAddPrefixToPoFunctions: ESLintUtils.RuleModule<"mustAddPrefixToPoFunctions", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustAddPrefixToPoFunctions;
@@ -1,8 +1,9 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { getFileNamePrefix, nodeTypes, getExportedFunctionNames } from '@flint/infra/ast-helpers';
3
+ import { getFileNamePrefix, nodeTypes, getExportedFunctionNames } from '@flint/infra/analysis';
4
4
  import { kebabToCamelCasePattern } from '@flint/infra/constants/rules-regex';
5
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
5
6
 
6
- var __defProp=Object['defineProperty'],__name=(_0x42252f,_0x4d846c)=>__defProp(_0x42252f,'name',{'value':_0x4d846c,'configurable':!![]});const constants={'url':'https://example.com/rules/','ruleName':'must-add-prefix-to-po-functions','messageIds':{'mustAddPrefixToPoFunctions':'mustAddPrefixToPoFunctions'},'meta':{'type':'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'](_0x34d613=>new URL(_0x34d613,constants['url'])['href']);function toCamelCase(_0x1ef699){return _0x1ef699['replace'](kebabToCamelCasePattern,(_0x148fe0,_0x583765)=>_0x583765['toUpperCase']());}__name(toCamelCase,'toCamelCase');function checkFunctionName(_0x54394a,_0xc33485,_0x547db6,_0x39a7e5){const _0x4ed1fa=toCamelCase(_0xc33485)+'Po';!_0x54394a['startsWith'](_0x4ed1fa)&&_0x547db6['report']({'node':_0x39a7e5,'messageId':constants['messageIds']['mustAddPrefixToPoFunctions'],'data':{'prefix':_0x4ed1fa,'name':_0x54394a}});}__name(checkFunctionName,'checkFunctionName');const mustAddPrefixToPoFunctions=createRule({'name':constants['ruleName'],'meta':constants['meta'],'create'(_0x3ae567){const _0x5ce513=_0x3ae567['filename'],_0x5bdf5c=getFileNamePrefix(_0x5ce513,constants['regexPatterns']['filenamePrefix']);if(!_0x5bdf5c)return {};return {'ExportNamedDeclaration'(_0x4bdb67){for(const _0x3f80f6 of getExportedFunctionNames(_0x4bdb67)){checkFunctionName(_0x3f80f6,_0x5bdf5c,_0x3ae567,_0x4bdb67);}},'ExportDefaultDeclaration'(_0x4484dc){const _0x227e5b=_0x4484dc['declaration'];_0x227e5b['type']===nodeTypes['functionDeclaration']&&_0x227e5b['id']&&checkFunctionName(_0x227e5b['id']['name'],_0x5bdf5c,_0x3ae567,_0x4484dc);}};},'defaultOptions':[]});
7
+ var __defProp=Object['defineProperty'],__name=(_0x1be636,_0x19e572)=>__defProp(_0x1be636,'name',{'value':_0x19e572,'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'](_0x235ccf=>new URL(_0x235ccf,url)['href']);function toCamelCase(_0x1d26b1){return _0x1d26b1['replace'](kebabToCamelCasePattern,(_0x59084b,_0x494e5e)=>_0x494e5e['toUpperCase']());}__name(toCamelCase,'toCamelCase');function checkFunctionName(_0x326bae,_0x37578c,_0x1e2207,_0xf4fb54){const _0x39b9d8=toCamelCase(_0x37578c)+'Po';!_0x326bae['startsWith'](_0x39b9d8)&&_0x1e2207['report']({'node':_0xf4fb54,'messageId':constants['messageIds']['mustAddPrefixToPoFunctions'],'data':{'prefix':_0x39b9d8,'name':_0x326bae}});}__name(checkFunctionName,'checkFunctionName');const mustAddPrefixToPoFunctions=createRule({'name':ruleName,'meta':constants['meta'],'create'(_0x20fe29){const _0x2f48c8=_0x20fe29['filename'],_0x3c4deb=getFileNamePrefix(_0x2f48c8,constants['regexPatterns']['filenamePrefix']);if(!_0x3c4deb)return {};return {'ExportNamedDeclaration'(_0xbb28e1){for(const _0x58c9e9 of getExportedFunctionNames(_0xbb28e1)){checkFunctionName(_0x58c9e9,_0x3c4deb,_0x20fe29,_0xbb28e1);}},'ExportDefaultDeclaration'(_0x53ed69){const _0x3d84eb=_0x53ed69['declaration'];_0x3d84eb['type']===nodeTypes['functionDeclaration']&&_0x3d84eb['id']&&checkFunctionName(_0x3d84eb['id']['name'],_0x3c4deb,_0x20fe29,_0x53ed69);}};},'defaultOptions':[]});
7
8
 
8
- export { mustAddPrefixToPoFunctions as default };
9
+ export { mustAddPrefixToPoFunctions as default, ruleName };
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
- import { createEslintRule } from '@flint/infra/utils/create-eslint-rule';
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,_0x2f68ce=>{return {'TSNonNullExpression'(_0x1b12cd){_0x2f68ce['report']({'node':_0x1b12cd,'messageId':ruleName});}};});
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,_0x5be164=>{return {'TSNonNullExpression'(_0x4df60e){_0x5be164['report']({'node':_0x4df60e,'messageId':ruleName});}};});
5
5
 
6
6
  export { mustAvoidNonNullAssertions as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-create-assert-functions-in-asserts-files";
2
3
  declare const mustCreateAssertFunctionsInAssertsFiles: ESLintUtils.RuleModule<"mustCreateAssertFunctionsInAssertsFiles", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustCreateAssertFunctionsInAssertsFiles;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { nodeTypes, getFileName } from '@flint/infra/ast-helpers';
3
+ import { nodeTypes, getFileName } from '@flint/infra/analysis';
4
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0x2b0834,_0x595c99)=>__defProp(_0x2b0834,'name',{'value':_0x595c99,'configurable':!![]});const constants={'url':'https://example.com/rules/','ruleName':'must-create-assert-functions-in-asserts-files','messageIds':{'mustCreateAssertFunctionsInAssertsFiles':'must-create-assert-functions-in-asserts-files'},'meta':{'type':'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'](_0x519c84=>''+constants['url']+_0x519c84);function checkFunctionName(_0x169de8,_0x19d5ea){let _0x2269de=![];const _0xa85e2d=/(^a|-a)sserts?([.-]|$)/,_0x22dc8f=/(^a|A)ssert($|[A-Z])/;return _0x19d5ea['id']&&_0x19d5ea['id']['type']===nodeTypes['identifier']&&_0x22dc8f['test'](_0x19d5ea['id']['name'])&&!_0xa85e2d['test'](getFileName(_0x169de8['filename']))&&(_0x169de8['report']({'node':_0x19d5ea['id'],'messageId':'mustCreateAssertFunctionsInAssertsFiles'}),_0x2269de=!![]),_0x2269de;}__name(checkFunctionName,'checkFunctionName');const mustCreateAssertFunctionsInAssertsFiles=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x595df9){return {'FunctionDeclaration'(_0x2b1a0d){checkFunctionName(_0x595df9,_0x2b1a0d);},'FunctionExpression'(_0x2ec2dc){!checkFunctionName(_0x595df9,_0x2ec2dc)&&_0x2ec2dc['parent']['type']===nodeTypes['variableDeclarator']&&checkFunctionName(_0x595df9,_0x2ec2dc['parent']);},'TSDeclareFunction'(_0x3f24cd){checkFunctionName(_0x595df9,_0x3f24cd);},'VariableDeclarator'(_0x1442d1){String(_0x1442d1['init']?.['type'])===nodeTypes['arrowFunctionExpression']&&checkFunctionName(_0x595df9,_0x1442d1);}};}});
6
+ var __defProp=Object['defineProperty'],__name=(_0x2b9e8f,_0x52a9c7)=>__defProp(_0x2b9e8f,'name',{'value':_0x52a9c7,'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'](_0x9b7290=>''+url+_0x9b7290);function checkFunctionName(_0x561d29,_0x56cfaa){let _0x492b4a=![];const _0x908e34=/(^a|-a)sserts?([.-]|$)/,_0x188b17=/(^a|A)ssert($|[A-Z])/;return _0x56cfaa['id']&&_0x56cfaa['id']['type']===nodeTypes['identifier']&&_0x188b17['test'](_0x56cfaa['id']['name'])&&!_0x908e34['test'](getFileName(_0x561d29['filename']))&&(_0x561d29['report']({'node':_0x56cfaa['id'],'messageId':'mustCreateAssertFunctionsInAssertsFiles'}),_0x492b4a=!![]),_0x492b4a;}__name(checkFunctionName,'checkFunctionName');const mustCreateAssertFunctionsInAssertsFiles=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0xfab9fc){return {'FunctionDeclaration'(_0x3325ea){checkFunctionName(_0xfab9fc,_0x3325ea);},'FunctionExpression'(_0x256bed){!checkFunctionName(_0xfab9fc,_0x256bed)&&_0x256bed['parent']['type']===nodeTypes['variableDeclarator']&&checkFunctionName(_0xfab9fc,_0x256bed['parent']);},'TSDeclareFunction'(_0x2fa100){checkFunctionName(_0xfab9fc,_0x2fa100);},'VariableDeclarator'(_0x30e121){String(_0x30e121['init']?.['type'])===nodeTypes['arrowFunctionExpression']&&checkFunctionName(_0xfab9fc,_0x30e121);}};}});
6
7
 
7
- export { mustCreateAssertFunctionsInAssertsFiles as default };
8
+ export { mustCreateAssertFunctionsInAssertsFiles as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-get-elements-in-tests-only-by-id";
2
3
  declare const mustGetElementsInTestsOnlyById: ESLintUtils.RuleModule<"useIdSelectorOnly", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustGetElementsInTestsOnlyById;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { isStringLiteral, nodeTypes, isTestFile, getMethodNameFromCallee } from '@flint/infra/ast-helpers';
3
+ import { isStringLiteral, nodeTypes, isTestFile, getMethodNameFromCallee } from '@flint/infra/analysis';
4
+ import { url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0x56e3c7,_0x55f179)=>__defProp(_0x56e3c7,'name',{'value':_0x55f179,'configurable':!![]});const constants={'ruleName':'must-get-elements-in-tests-only-by-id','url':'https://example.com/rules/','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\x20\x20\x20\x20\x20\x20\x20\x20\x0a####\x20Wrong:\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0aconst\x20button\x20=\x20page.locator(\x22.btn-primary\x22);\x0aawait\x20button.click();\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0a####\x20Correct:\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0aconst\x20button\x20=\x20page.locator(\x22#foo-button\x22);\x0aawait\x20button.click();\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0a####\x20Why:\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0aUsing\x20id\x20ensures\x20consistent\x20and\x20reliable\x20test\x20execution,\x20reducing\x20maintenance\x20efforts\x20and\x20preventing\x20flaky\x20tests.'},'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'])},createRule=ESLintUtils['RuleCreator'](_0x356a44=>''+constants['url']+_0x356a44);function getStaticStringValue(_0x5116ff){let _0x497cc7;if(isStringLiteral(_0x5116ff))_0x497cc7=_0x5116ff['value'];else _0x5116ff['type']===nodeTypes['templateLiteral']&&_0x5116ff['expressions']['length']===-0x24e0+-0x2a*-0xca+-0xef*-0x4&&(_0x497cc7=_0x5116ff['quasis'][-0xf4a+-0x209d+0x1*0x2fe7]?.['value']['raw']);return _0x497cc7;}__name(getStaticStringValue,'getStaticStringValue');function isInvalidCssSelector(_0x1c5241){const _0x2861d4=getStaticStringValue(_0x1c5241);return !!_0x2861d4&&!_0x2861d4['trim']()['startsWith']('#');}__name(isInvalidCssSelector,'isInvalidCssSelector');function isInvalidNonCssSelector(_0x36f904){const _0x3e5861=getStaticStringValue(_0x36f904);return !!_0x3e5861&&_0x3e5861['trim']()['startsWith']('#');}__name(isInvalidNonCssSelector,'isInvalidNonCssSelector');const mustGetElementsInTestsOnlyById=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x522144){if(!isTestFile(_0x522144['filename']))return {};return {'CallExpression'(_0x1b1da4){const _0x32a104=getMethodNameFromCallee(_0x1b1da4['callee']);if(!_0x32a104)return;const _0x146515=_0x1b1da4['arguments'][0x1*-0x18be+-0x1d5e+0x361c];if(!_0x146515)return;if(constants['cssSelectorMethods']['has'](_0x32a104)&&isInvalidCssSelector(_0x146515)){_0x522144['report']({'node':_0x146515,'messageId':constants['messageIds']['useIdSelectorOnly']});return;}constants['nonCssSelectorMethods']['has'](_0x32a104)&&isInvalidNonCssSelector(_0x146515)&&_0x522144['report']({'node':_0x146515,'messageId':constants['messageIds']['useIdSelectorOnly']});}};}});
6
+ var __defProp=Object['defineProperty'],__name=(_0x233a79,_0x3e1a9b)=>__defProp(_0x233a79,'name',{'value':_0x3e1a9b,'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.'},'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'])},createRule=ESLintUtils['RuleCreator'](_0x252afc=>''+url+_0x252afc);function getStaticStringValue(_0x1148a9){let _0x1c9e92;if(isStringLiteral(_0x1148a9))_0x1c9e92=_0x1148a9['value'];else _0x1148a9['type']===nodeTypes['templateLiteral']&&_0x1148a9['expressions']['length']===0x4*-0x3a4+-0x1bec+0x2a7c&&(_0x1c9e92=_0x1148a9['quasis'][-0xe69+-0x351*0x9+-0x2*-0x1621]?.['value']['raw']);return _0x1c9e92;}__name(getStaticStringValue,'getStaticStringValue');function isInvalidCssSelector(_0x38137e){const _0x2b1c90=getStaticStringValue(_0x38137e);return !!_0x2b1c90&&!_0x2b1c90['trim']()['startsWith']('#');}__name(isInvalidCssSelector,'isInvalidCssSelector');function isInvalidNonCssSelector(_0x767e1f){const _0x2d9346=getStaticStringValue(_0x767e1f);return !!_0x2d9346&&_0x2d9346['trim']()['startsWith']('#');}__name(isInvalidNonCssSelector,'isInvalidNonCssSelector');const mustGetElementsInTestsOnlyById=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x1a2537){if(!isTestFile(_0x1a2537['filename']))return {};return {'CallExpression'(_0x5c0c25){const _0x2d2a29=getMethodNameFromCallee(_0x5c0c25['callee']);if(!_0x2d2a29)return;const _0x5b275a=_0x5c0c25['arguments'][-0x2263*-0x1+0xd*-0x1eb+-0x974];if(!_0x5b275a)return;if(constants['cssSelectorMethods']['has'](_0x2d2a29)&&isInvalidCssSelector(_0x5b275a)){_0x1a2537['report']({'node':_0x5b275a,'messageId':constants['messageIds']['useIdSelectorOnly']});return;}constants['nonCssSelectorMethods']['has'](_0x2d2a29)&&isInvalidNonCssSelector(_0x5b275a)&&_0x1a2537['report']({'node':_0x5b275a,'messageId':constants['messageIds']['useIdSelectorOnly']});}};}});
6
7
 
7
- export { mustGetElementsInTestsOnlyById as default };
8
+ export { mustGetElementsInTestsOnlyById as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-name-ui-tests-component-condition-expected-result";
2
3
  declare const mustNameUiTestsComponentConditionExpectedResult: ESLintUtils.RuleModule<"mustNameUiTestsComponentConditionExpectedResult", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNameUiTestsComponentConditionExpectedResult;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { getMethodNameFromCallee, nodeTypes } from '@flint/infra/ast-helpers';
3
+ import { getMethodNameFromCallee, nodeTypes } from '@flint/infra/analysis';
4
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0x2b6789,_0x4d6626)=>__defProp(_0x2b6789,'name',{'value':_0x4d6626,'configurable':!![]});const constants={'ruleName':'must-name-ui-tests-component-condition-expected-result','url':'https://example.com/rules/','messageIds':{'mustNameUiTestsComponentConditionExpectedResult':'mustNameUiTestsComponentConditionExpectedResult'},'meta':{'type':'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\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\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`,\x20\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(_0x9fc702){return getMethodNameFromCallee(_0x9fc702['callee'])==='uiTest'||getMethodNameFromCallee(_0x9fc702['callee'],'uiTest')==='fixme';}__name(isUiTest,'isUiTest');function report(_0x5a3eb0,_0x1d2067){_0x5a3eb0['report']({'node':_0x1d2067,'messageId':constants['messageIds']['mustNameUiTestsComponentConditionExpectedResult']});}__name(report,'report');function isComponentName(_0x1cab8b){return _0x1cab8b['some'](_0x4be541=>_0x4be541['type']===nodeTypes['memberExpression']&&_0x4be541['object']['type']===nodeTypes['identifier']&&_0x4be541['property']['type']===nodeTypes['identifier']);}__name(isComponentName,'isComponentName');function isDash(_0x8bd074){return _0x8bd074['some'](_0x1b3a8c=>_0x1b3a8c['value']['cooked']['includes']('\x20-\x20'));}__name(isDash,'isDash');function shouldReportUiTestNameError(_0x1bc813){let _0x1cde3d=![];return isUiTest(_0x1bc813)&&(_0x1bc813['arguments'][-0x24*0xde+-0x2139+0x15f*0x2f]?.['type']===nodeTypes['templateLiteral']?_0x1cde3d=!isComponentName(_0x1bc813['arguments'][0x519+0x739*0x4+-0x21fd]['expressions'])||!isDash(_0x1bc813['arguments'][-0x5*0x56b+0xfc5+-0x19e*-0x7]['quasis']):_0x1cde3d=!![]),_0x1cde3d;}__name(shouldReportUiTestNameError,'shouldReportUiTestNameError');const createRule=ESLintUtils['RuleCreator'](_0xa93db9=>''+constants['url']+_0xa93db9),mustNameUiTestsComponentConditionExpectedResult=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x2557f6){return {'CallExpression'(_0x2c42d6){shouldReportUiTestNameError(_0x2c42d6)&&report(_0x2557f6,_0x2c42d6);}};}});
6
+ var __defProp=Object['defineProperty'],__name=(_0x3babf8,_0x1c469f)=>__defProp(_0x3babf8,'name',{'value':_0x1c469f,'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(_0xa66dc0){return getMethodNameFromCallee(_0xa66dc0['callee'])==='uiTest'||getMethodNameFromCallee(_0xa66dc0['callee'],'uiTest')==='fixme';}__name(isUiTest,'isUiTest');function report(_0x32c56c,_0x480e9c){_0x32c56c['report']({'node':_0x480e9c,'messageId':constants['messageIds']['mustNameUiTestsComponentConditionExpectedResult']});}__name(report,'report');function isComponentName(_0x53b042){return _0x53b042['some'](_0x576f64=>_0x576f64['type']===nodeTypes['memberExpression']&&_0x576f64['object']['type']===nodeTypes['identifier']&&_0x576f64['property']['type']===nodeTypes['identifier']);}__name(isComponentName,'isComponentName');function isDash(_0x1610e1){return _0x1610e1['some'](_0x2aac19=>_0x2aac19['value']['cooked']['includes']('\x20-\x20'));}__name(isDash,'isDash');function shouldReportUiTestNameError(_0x562a0e){let _0x25dd23=![];return isUiTest(_0x562a0e)&&(_0x562a0e['arguments'][0xb3f*-0x3+0xa73+-0x10f*-0x16]?.['type']===nodeTypes['templateLiteral']?_0x25dd23=!isComponentName(_0x562a0e['arguments'][0x14a0+-0x1d+0x59*-0x3b]['expressions'])||!isDash(_0x562a0e['arguments'][0x439*0x1+0x29*0xb5+0x28e*-0xd]['quasis']):_0x25dd23=!![]),_0x25dd23;}__name(shouldReportUiTestNameError,'shouldReportUiTestNameError');const createRule=ESLintUtils['RuleCreator'](_0x3f9464=>''+url+_0x3f9464),mustNameUiTestsComponentConditionExpectedResult=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x538cf5){return {'CallExpression'(_0x519d19){shouldReportUiTestNameError(_0x519d19)&&report(_0x538cf5,_0x519d19);}};}});
6
7
 
7
- export { mustNameUiTestsComponentConditionExpectedResult as default };
8
+ export { mustNameUiTestsComponentConditionExpectedResult as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-not-add-files-and-code-in-lib-folder";
2
3
  declare const mustNotAddFilesAndCodeInLibFolder: ESLintUtils.RuleModule<"noLibFolder", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNotAddFilesAndCodeInLibFolder;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import _0x3f8f01__default from 'path';
3
+ import _0x25f9dd__default from 'path';
4
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- const constants={'ruleName':'must-not-add-files-and-code-in-lib-folder','urlBase':'https://example.com/rules/','messageIds':{'noLibFolder':'noLibFolder'},'meta':{'type':'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'](_0x71f77e=>''+constants['urlBase']+_0x71f77e),mustNotAddFilesAndCodeInLibFolder=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x12c18a){const _0x30925d=_0x12c18a['filename']||'',_0x2334aa=_0x3f8f01__default['normalize'](_0x30925d)['replace'](/\\/g,'/'),_0xd688f5=_0x2334aa['includes'](constants['libPathSegment']);if(!_0xd688f5)return {};return {'Program'(_0x42f2d3){_0x12c18a['report']({'node':_0x42f2d3,'messageId':constants['messageIds']['noLibFolder']});}};}});
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'](_0x122a1b=>''+url+_0x122a1b),mustNotAddFilesAndCodeInLibFolder=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x350276){const _0x52a3cd=_0x350276['filename']||'',_0x22bc5e=_0x25f9dd__default['normalize'](_0x52a3cd)['replace'](/\\/g,'/'),_0x39cf43=_0x22bc5e['includes'](constants['libPathSegment']);if(!_0x39cf43)return {};return {'Program'(_0x58208b){_0x350276['report']({'node':_0x58208b,'messageId':constants['messageIds']['noLibFolder']});}};}});
6
7
 
7
- export { mustNotAddFilesAndCodeInLibFolder as default };
8
+ export { mustNotAddFilesAndCodeInLibFolder as default, ruleName };
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
- import { createEslintRule } from '@flint/infra/utils/create-eslint-rule';
3
- import _0x3cfde7__default from 'fs';
2
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
3
+ import _0x3097f4__default from 'fs';
4
4
 
5
- var __defProp=Object['defineProperty'],__name=(_0x539e08,_0x3750f7)=>__defProp(_0x539e08,'name',{'value':_0x3750f7,'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(_0x5a3385){return {'Program'(){const _0x494269=_0x5a3385['filename'];if(_0x494269['endsWith'](constants['ends'])){const _0x2b46c5=_0x494269['replace'](constants['ends'],constants['reactComponentEnds']),_0x51dbb6=_0x2b46c5['replace'](/\\/g,'/');!_0x3cfde7__default['existsSync'](_0x51dbb6)&&_0x5a3385['report']({'messageId':ruleName,'loc':{'line':0x1,'column':0x0}});}}};},'create'));const constants={'reactComponentEnds':'.tsx','ends':'.funcs.ts'};
5
+ var __defProp=Object['defineProperty'],__name=(_0x43f110,_0xd43be1)=>__defProp(_0x43f110,'name',{'value':_0xd43be1,'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(_0x437570){return {'Program'(){const _0x283058=_0x437570['filename'];if(_0x283058['endsWith'](constants['ends'])){const _0x4d0f9a=_0x283058['replace'](constants['ends'],constants['reactComponentEnds']),_0x115041=_0x4d0f9a['replace'](/\\/g,'/');!_0x3097f4__default['existsSync'](_0x115041)&&_0x437570['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 };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-not-declare-func-inside-another-func";
2
3
  declare const mustNotDeclareFuncInsideAnotherFunc: ESLintUtils.RuleModule<"mustNotDeclareFuncInsideAnotherFunc", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNotDeclareFuncInsideAnotherFunc;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { nodeTypes, getFunctionName, isHookByName, isComponentLikeFunction, isSmallLambda, isHookCall } from '@flint/infra/ast-helpers';
3
+ import { nodeTypes, getFunctionName, isHookByName, isComponentLikeFunction, isSmallLambda, isHookCall } from '@flint/infra/analysis';
4
+ import { url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0xfa6578,_0x3b3fcf)=>__defProp(_0xfa6578,'name',{'value':_0x3b3fcf,'configurable':!![]});const constants={'url':'https://example.com/rules/','ruleName':'must-not-declare-func-inside-another-func','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'](_0x2756b9=>''+constants['url']+_0x2756b9),mustNotDeclareFuncInsideAnotherFunc=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x3c4633){const _0x4a140d=[],_0x32a5a8=new Set([nodeTypes['methodDefinition'],nodeTypes['property'],nodeTypes['callExpression'],nodeTypes['assignmentExpression']]),_0x105fb9=[nodeTypes['functionDeclaration'],nodeTypes['functionExpression'],nodeTypes['arrowFunctionExpression']]['join'](',');return {[_0x105fb9]:_0x320061=>{const _0x53bdad=_0x4a140d['at'](-(0x469*0x5+-0x1*0x2b+-0x15e1));_0x53bdad&&_0x53bdad['nestedFunctions']['push'](_0x320061),_0x4a140d['push']({'node':_0x320061,'containsHookCall':![],'nestedFunctions':[]});},'CallExpression':__name(_0xaa1dc=>{const _0x377746=_0x4a140d['at'](-(-0x1ed*0x11+0x13*0x1d1+0x3*-0x97));if(!_0x377746)return;isHookCall(_0xaa1dc['callee'])&&(_0x377746['containsHookCall']=!![]);},'CallExpression'),[_0x105fb9+':exit']:()=>{const _0x2c0b84=_0x4a140d['pop']();if(!_0x2c0b84)return;const _0x51152f=getFunctionName(_0x2c0b84['node']);if(!_0x51152f)return;const _0x1f9ca1=isHookByName(_0x51152f)&&_0x2c0b84['containsHookCall'],_0x7cc2dc=isComponentLikeFunction(_0x2c0b84['node']),_0x184dfb=_0x1f9ca1||_0x7cc2dc;if(!_0x184dfb)for(const _0x39cd4c of _0x2c0b84['nestedFunctions']){const _0x159cae=_0x39cd4c['parent']&&_0x32a5a8['has'](_0x39cd4c['parent']['type']),_0x43b0e2=isSmallLambda(_0x39cd4c);!_0x159cae&&!_0x43b0e2&&_0x3c4633['report']({'node':_0x39cd4c,'messageId':constants['messageIds']['mustNotDeclareFuncInsideAnotherFunc']});}}};}});
6
+ var __defProp=Object['defineProperty'],__name=(_0x166114,_0x5d1af4)=>__defProp(_0x166114,'name',{'value':_0x5d1af4,'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'](_0x2aed0d=>''+url+_0x2aed0d),mustNotDeclareFuncInsideAnotherFunc=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0xae5d26){const _0x1209e8=[],_0x5a899e=new Set([nodeTypes['methodDefinition'],nodeTypes['property'],nodeTypes['callExpression'],nodeTypes['assignmentExpression']]),_0x126100=[nodeTypes['functionDeclaration'],nodeTypes['functionExpression'],nodeTypes['arrowFunctionExpression']]['join'](',');return {[_0x126100]:_0x295edb=>{const _0x3e5f14=_0x1209e8['at'](-(0x71f*0x3+0x1*0x232f+-0x388b));_0x3e5f14&&_0x3e5f14['nestedFunctions']['push'](_0x295edb),_0x1209e8['push']({'node':_0x295edb,'containsHookCall':![],'nestedFunctions':[]});},'CallExpression':__name(_0x30eeeb=>{const _0xeb67ef=_0x1209e8['at'](-(0x2*0x102b+0x30c+-0x3*0xbcb));if(!_0xeb67ef)return;isHookCall(_0x30eeeb['callee'])&&(_0xeb67ef['containsHookCall']=!![]);},'CallExpression'),[_0x126100+':exit']:()=>{const _0x28ecb7=_0x1209e8['pop']();if(!_0x28ecb7)return;const _0x1f9ccf=getFunctionName(_0x28ecb7['node']);if(!_0x1f9ccf)return;const _0x1895d9=isHookByName(_0x1f9ccf)&&_0x28ecb7['containsHookCall'],_0x2dcaa8=isComponentLikeFunction(_0x28ecb7['node']),_0x23b1f7=_0x1895d9||_0x2dcaa8;if(!_0x23b1f7)for(const _0x59238a of _0x28ecb7['nestedFunctions']){const _0x4eb0ee=_0x59238a['parent']&&_0x5a899e['has'](_0x59238a['parent']['type']),_0x1b0a98=isSmallLambda(_0x59238a);!_0x4eb0ee&&!_0x1b0a98&&_0xae5d26['report']({'node':_0x59238a,'messageId':constants['messageIds']['mustNotDeclareFuncInsideAnotherFunc']});}}};}});
6
7
 
7
- export { mustNotDeclareFuncInsideAnotherFunc as default };
8
+ export { mustNotDeclareFuncInsideAnotherFunc as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-not-import-react";
2
3
  declare const mustNotImportReact: ESLintUtils.RuleModule<"mustNotImportReact", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNotImportReact;
@@ -1,8 +1,9 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import * as _0x3f8f01 from 'path';
4
- import * as _0x3cfde7 from 'fs';
3
+ import * as _0x25f9dd from 'path';
4
+ import * as _0x3097f4 from 'fs';
5
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
5
6
 
6
- var __defProp=Object['defineProperty'],__name=(_0x10376e,_0xefc01c)=>__defProp(_0x10376e,'name',{'value':_0xefc01c,'configurable':!![]});const funcFileRegex=/\.func\.(ts|tsx)$/,forbiddenImports=['react','react-dom','react/jsx-runtime'],constants={'url':'https://example.com/rules/','ruleName':'must-not-import-react','messageIds':{'mustNotImportReact':'mustNotImportReact'},'meta':{'type':'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'](_0x2e1344=>''+constants['url']+_0x2e1344),fileCache=new Map();function resolveFilePath(_0x41a146,_0x1dfe2c){if(!_0x41a146['startsWith']('.'))return void(0x3aa+-0xdb9+0xa0f);const _0x1d695c=_0x3f8f01['resolve'](_0x1dfe2c,_0x41a146),_0x45c4f6=['.ts','.tsx','.js','.jsx'],_0x44eeac=[_0x1d695c,..._0x45c4f6['map'](_0x9328ae=>_0x1d695c+_0x9328ae),_0x3f8f01['join'](_0x1d695c,'index.ts'),_0x3f8f01['join'](_0x1d695c,'index.tsx'),_0x3f8f01['join'](_0x1d695c,'index.js'),_0x3f8f01['join'](_0x1d695c,'index.jsx')];return _0x44eeac['find'](_0x3c9b40=>_0x3cfde7['existsSync'](_0x3c9b40))??void(0x314*0x3+0x33f*-0x7+0x3*0x47f);}__name(resolveFilePath,'resolveFilePath');function fileImportsReact(_0x32b515,_0x1e3750=new Set()){let _0x2552fc=![];if(fileCache['has'](_0x32b515))_0x2552fc=fileCache['get'](_0x32b515)??![];else {if(!_0x1e3750['has'](_0x32b515)&&_0x3cfde7['existsSync'](_0x32b515)){_0x1e3750['add'](_0x32b515);const _0xe09801=_0x3cfde7['readFileSync'](_0x32b515,'utf8'),_0x2987bf=/from\s+['"]react['"]/,_0x5ba21a=/import\s+[\s\S]{0,200}?from\s+['"]([^'"]{1,200})['"]/g;if(_0x2987bf['test'](_0xe09801))_0x2552fc=!![];else for(const _0x2fdc79 of _0xe09801['matchAll'](_0x5ba21a)){const _0x536bb7=_0x2fdc79[-0xca9+-0x1fed+0xedd*0x3],_0x2a1f63=resolveFilePath(_0x536bb7,_0x3f8f01['dirname'](_0x32b515));if(_0x2a1f63&&fileImportsReact(_0x2a1f63,_0x1e3750)){_0x2552fc=!![];break;}}}}return fileCache['set'](_0x32b515,_0x2552fc),_0x2552fc;}__name(fileImportsReact,'fileImportsReact');const mustNotImportReact=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x3a65cd){const _0x2d21d8=_0x3a65cd['filename'];if(!funcFileRegex['test'](_0x2d21d8))return {};return {'ImportDeclaration'(_0x2583c2){const _0x330679=_0x2583c2['source']['value'];if(typeof _0x330679!=='string')return;if(forbiddenImports['includes'](_0x330679['toLowerCase']())){_0x3a65cd['report']({'node':_0x2583c2,'messageId':'mustNotImportReact'});return;}if(_0x330679['startsWith']('.')){const _0x5ae267=resolveFilePath(_0x330679,_0x3f8f01['dirname'](_0x2d21d8));_0x5ae267&&fileImportsReact(_0x5ae267)&&_0x3a65cd['report']({'node':_0x2583c2,'messageId':'mustNotImportReact'});}}};}});
7
+ var __defProp=Object['defineProperty'],__name=(_0x447442,_0x571729)=>__defProp(_0x447442,'name',{'value':_0x571729,'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'](_0x2eef42=>''+url+_0x2eef42),fileCache=new Map();function resolveFilePath(_0x2cf577,_0xa35958){if(!_0x2cf577['startsWith']('.'))return void(-0x3*-0x6ee+-0x1761+0x297);const _0x3b180a=_0x25f9dd['resolve'](_0xa35958,_0x2cf577),_0x3ec8d2=['.ts','.tsx','.js','.jsx'],_0x44e275=[_0x3b180a,..._0x3ec8d2['map'](_0x324d8c=>_0x3b180a+_0x324d8c),_0x25f9dd['join'](_0x3b180a,'index.ts'),_0x25f9dd['join'](_0x3b180a,'index.tsx'),_0x25f9dd['join'](_0x3b180a,'index.js'),_0x25f9dd['join'](_0x3b180a,'index.jsx')];return _0x44e275['find'](_0x3fa1e3=>_0x3097f4['existsSync'](_0x3fa1e3))??void(0x12e7*-0x1+-0x110f+0x23f6);}__name(resolveFilePath,'resolveFilePath');function fileImportsReact(_0x4a3ebb,_0x2e617a=new Set()){let _0x3f53c2=![];if(fileCache['has'](_0x4a3ebb))_0x3f53c2=fileCache['get'](_0x4a3ebb)??![];else {if(!_0x2e617a['has'](_0x4a3ebb)&&_0x3097f4['existsSync'](_0x4a3ebb)){_0x2e617a['add'](_0x4a3ebb);const _0x160950=_0x3097f4['readFileSync'](_0x4a3ebb,'utf8'),_0x1ee814=/from\s+['"]react['"]/,_0x440ec9=/import\s+[\s\S]{0,200}?from\s+['"]([^'"]{1,200})['"]/g;if(_0x1ee814['test'](_0x160950))_0x3f53c2=!![];else for(const _0x20f266 of _0x160950['matchAll'](_0x440ec9)){const _0x355c66=_0x20f266[-0x1*-0x157+0x25aa+-0x100*0x27],_0x4aea69=resolveFilePath(_0x355c66,_0x25f9dd['dirname'](_0x4a3ebb));if(_0x4aea69&&fileImportsReact(_0x4aea69,_0x2e617a)){_0x3f53c2=!![];break;}}}}return fileCache['set'](_0x4a3ebb,_0x3f53c2),_0x3f53c2;}__name(fileImportsReact,'fileImportsReact');const mustNotImportReact=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x12ce36){const _0x3e0195=_0x12ce36['filename'];if(!funcFileRegex['test'](_0x3e0195))return {};return {'ImportDeclaration'(_0x48252e){const _0x19ee6f=_0x48252e['source']['value'];if(typeof _0x19ee6f!=='string')return;if(forbiddenImports['includes'](_0x19ee6f['toLowerCase']())){_0x12ce36['report']({'node':_0x48252e,'messageId':'mustNotImportReact'});return;}if(_0x19ee6f['startsWith']('.')){const _0x233c44=resolveFilePath(_0x19ee6f,_0x25f9dd['dirname'](_0x3e0195));_0x233c44&&fileImportsReact(_0x233c44)&&_0x12ce36['report']({'node':_0x48252e,'messageId':'mustNotImportReact'});}}};}});
7
8
 
8
- export { mustNotImportReact as default };
9
+ export { mustNotImportReact as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-not-use-emojis";
2
3
  declare const mustNotUseEmojis: ESLintUtils.RuleModule<"mustNotUseEmojis", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNotUseEmojis;