@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,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { nodeTypes } from '@flint/infra/ast-helpers';
3
+ import { nodeTypes } from '@flint/infra/analysis';
4
+ import { url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0x57fc00,_0x48471d)=>__defProp(_0x57fc00,'name',{'value':_0x48471d,'configurable':!![]});const constants={'emojiRegex':new RegExp('[\x5cp{Emoji_Presentation}\x5cp{Extended_Pictographic}][\x5cu{1F3FB}-\x5cu{1F3FF}]?[\x5cuFE0F\x5cuFE0E]?(?:\x5cu200D[\x5cp{Emoji_Presentation}\x5cp{Extended_Pictographic}][\x5cu{1F3FB}-\x5cu{1F3FF}]?[\x5cuFE0F\x5cuFE0E]?)*','gu'),'url':'https://example.com/rules/','ruleName':'must-not-use-emojis','messageIds':{'mustNotUseEmojis':'mustNotUseEmojis'},'meta':{'type':'suggestion','docs':{'description':'Emoji\x20should\x20not\x20be\x20used.'},'messages':{'mustNotUseEmojis':'must-not-use-emojis\x0a###\x20**Must\x20not**\x20use\x20emojis.\x0a\x0a####\x20Wrong:\x0a\x0aconsole.error(\x22✅\x20Error:\x22);\x0a\x0a####\x20Correct:\x0a\x0aconsole.error(\x22Error:\x22);\x0a\x0a####\x20Why:\x0a\x0aEmojis\x20may\x20not\x20be\x20supported\x20in\x20older\x20versions\x20of\x20consoles\x20or\x20logs.'},'schema':[],'fixable':'code'}},createRule=ESLintUtils['RuleCreator'](_0x1421a5=>''+constants['url']+_0x1421a5);function fixTemplateLiteralEmojis(_0x3a8df7,_0xeebc39,_0x5af2cd){const _0xc66c2f=_0x5af2cd['getText'](_0x3a8df7),_0x177976=_0xc66c2f['replace'](constants['emojiRegex'],'');return _0xeebc39['replaceText'](_0x3a8df7,_0x177976);}__name(fixTemplateLiteralEmojis,'fixTemplateLiteralEmojis');function fixLiteralEmojis(_0x2b6764,_0x43b2d8){const _0x37eeeb=_0x2b6764['value']['replace'](constants['emojiRegex'],''),_0x2c3432=JSON['stringify'](_0x37eeeb);return _0x43b2d8['replaceText'](_0x2b6764,_0x2c3432);}__name(fixLiteralEmojis,'fixLiteralEmojis');function fixCommentEmojis(_0x5c15da,_0x426098){const _0x44a5a9=_0x5c15da['value']['replace'](constants['emojiRegex'],'');let _0x45ad3f;return _0x5c15da['type']===nodeTypes['Line']?_0x45ad3f='//'+_0x44a5a9:_0x45ad3f='/*'+_0x44a5a9+'*/',_0x426098['replaceText'](_0x5c15da,_0x45ad3f);}__name(fixCommentEmojis,'fixCommentEmojis');function hasEmoji(_0xac7c5f){return constants['emojiRegex']['lastIndex']=-0xb9*-0xf+-0xc52+-0x17b*-0x1,constants['emojiRegex']['test'](_0xac7c5f);}__name(hasEmoji,'hasEmoji');function hasEmojiInQuasis(_0x381d5b){return _0x381d5b['some'](_0x5ff442=>hasEmoji(_0x5ff442['value']['raw']));}__name(hasEmojiInQuasis,'hasEmojiInQuasis');const mustNotUseEmojis=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x206ece){const _0xf3336f=_0x206ece['sourceCode'];return {[nodeTypes['literal']](_0x18f78f){typeof _0x18f78f['value']==='string'&&hasEmoji(_0x18f78f['value'])&&_0x206ece['report']({'node':_0x18f78f,'messageId':constants['messageIds']['mustNotUseEmojis'],'fix'(_0x258902){return fixLiteralEmojis(_0x18f78f,_0x258902);}});},[nodeTypes['templateLiteral']](_0x3e582e){if(!hasEmojiInQuasis(_0x3e582e['quasis']))return;_0x206ece['report']({'node':_0x3e582e,'messageId':constants['messageIds']['mustNotUseEmojis'],'fix'(_0x2181d0){return fixTemplateLiteralEmojis(_0x3e582e,_0x2181d0,_0xf3336f);}});},[nodeTypes['program']](){const _0x22644b=_0xf3336f['getAllComments']();for(const _0x38a512 of _0x22644b){hasEmoji(_0x38a512['value'])&&_0x206ece['report']({'loc':_0x38a512['loc'],'messageId':constants['messageIds']['mustNotUseEmojis'],'fix'(_0xfaa013){return fixCommentEmojis(_0x38a512,_0xfaa013);}});}}};}});
6
+ var __defProp=Object['defineProperty'],__name=(_0x2d2d21,_0x59e69b)=>__defProp(_0x2d2d21,'name',{'value':_0x59e69b,'configurable':!![]});const ruleName='must-not-use-emojis';const constants={'emojiRegex':new RegExp('[\x5cp{Emoji_Presentation}\x5cp{Extended_Pictographic}][\x5cu{1F3FB}-\x5cu{1F3FF}]?[\x5cuFE0F\x5cuFE0E]?(?:\x5cu200D[\x5cp{Emoji_Presentation}\x5cp{Extended_Pictographic}][\x5cu{1F3FB}-\x5cu{1F3FF}]?[\x5cuFE0F\x5cuFE0E]?)*','gu'),'messageIds':{'mustNotUseEmojis':'mustNotUseEmojis'},'meta':{'type':'suggestion','docs':{'description':'Emoji\x20should\x20not\x20be\x20used.'},'messages':{'mustNotUseEmojis':'must-not-use-emojis\x0a###\x20**Must\x20not**\x20use\x20emojis.\x0a\x0a####\x20Wrong:\x0a\x0aconsole.error(\x22✅\x20Error:\x22);\x0a\x0a####\x20Correct:\x0a\x0aconsole.error(\x22Error:\x22);\x0a\x0a####\x20Why:\x0a\x0aEmojis\x20may\x20not\x20be\x20supported\x20in\x20older\x20versions\x20of\x20consoles\x20or\x20logs.'},'schema':[],'fixable':'code'}},createRule=ESLintUtils['RuleCreator'](_0x320ce2=>''+url+_0x320ce2);function fixTemplateLiteralEmojis(_0x2f52d6,_0x47ea60,_0x3e7157){const _0xead776=_0x3e7157['getText'](_0x2f52d6),_0x5525c3=_0xead776['replace'](constants['emojiRegex'],'');return _0x47ea60['replaceText'](_0x2f52d6,_0x5525c3);}__name(fixTemplateLiteralEmojis,'fixTemplateLiteralEmojis');function fixLiteralEmojis(_0x1d9bda,_0x4ee553){const _0x114ff4=_0x1d9bda['value']['replace'](constants['emojiRegex'],''),_0x36a2c5=JSON['stringify'](_0x114ff4);return _0x4ee553['replaceText'](_0x1d9bda,_0x36a2c5);}__name(fixLiteralEmojis,'fixLiteralEmojis');function fixCommentEmojis(_0x1e90c0,_0x3dc2c6){const _0x39cb76=_0x1e90c0['value']['replace'](constants['emojiRegex'],'');let _0x4489cc;return _0x1e90c0['type']===nodeTypes['Line']?_0x4489cc='//'+_0x39cb76:_0x4489cc='/*'+_0x39cb76+'*/',_0x3dc2c6['replaceText'](_0x1e90c0,_0x4489cc);}__name(fixCommentEmojis,'fixCommentEmojis');function hasEmoji(_0xeea4fe){return constants['emojiRegex']['lastIndex']=-0x1b7*0x1+0x3*0x599+-0xf14,constants['emojiRegex']['test'](_0xeea4fe);}__name(hasEmoji,'hasEmoji');function hasEmojiInQuasis(_0x247b7b){return _0x247b7b['some'](_0x1bb452=>hasEmoji(_0x1bb452['value']['raw']));}__name(hasEmojiInQuasis,'hasEmojiInQuasis');const mustNotUseEmojis=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x57ec36){const _0x5c5887=_0x57ec36['sourceCode'];return {[nodeTypes['literal']](_0x3f5aa9){typeof _0x3f5aa9['value']==='string'&&hasEmoji(_0x3f5aa9['value'])&&_0x57ec36['report']({'node':_0x3f5aa9,'messageId':constants['messageIds']['mustNotUseEmojis'],'fix'(_0x30ce01){return fixLiteralEmojis(_0x3f5aa9,_0x30ce01);}});},[nodeTypes['templateLiteral']](_0x8af61e){if(!hasEmojiInQuasis(_0x8af61e['quasis']))return;_0x57ec36['report']({'node':_0x8af61e,'messageId':constants['messageIds']['mustNotUseEmojis'],'fix'(_0x27a499){return fixTemplateLiteralEmojis(_0x8af61e,_0x27a499,_0x5c5887);}});},[nodeTypes['program']](){const _0x1cd4b8=_0x5c5887['getAllComments']();for(const _0x409c9e of _0x1cd4b8){hasEmoji(_0x409c9e['value'])&&_0x57ec36['report']({'loc':_0x409c9e['loc'],'messageId':constants['messageIds']['mustNotUseEmojis'],'fix'(_0x58f85a){return fixCommentEmojis(_0x409c9e,_0x58f85a);}});}}};}});
6
7
 
7
- export { mustNotUseEmojis as default };
8
+ export { mustNotUseEmojis as default, ruleName };
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
- import { createEslintRule } from '@flint/infra/utils/create-eslint-rule';
3
- import { nodeTypes, isIdentifier, isNameMatch, getRootTSType } from '@flint/infra/ast-helpers';
2
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
3
+ import { nodeTypes, isIdentifier, isNameMatch, getRootTSType } from '@flint/infra/analysis';
4
4
 
5
- var __defProp=Object['defineProperty'],__name=(_0x15189e,_0xa11610)=>__defProp(_0x15189e,'name',{'value':_0xa11610,'configurable':!![]});const ruleName='must-not-use-indexed-access-type-in-function-params';const ruleContent='\x0a###\x20**Must\x20not**\x20use\x20indexed\x20access\x20type\x20in\x20function\x20parameters\x0a\x0a####\x20Wrong\x0a\x0afunction\x20foo(bar:\x20baz[\x22qux\x22])\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0a####\x20Correct\x0a\x0aexport\x20function\x20foo(bar:\x20baz)\x20{\x0a\x20\x20\x20\x20return\x20waldo(bar.qux);\x0a}\x0a\x0a####\x20Why\x0a\x0aIndexed\x20access\x20types\x20in\x20function\x20parameters\x20make\x20signatures\x20harder\x20to\x20read\x20and\x20understand.\x0a',constants={'functionParamsSelector':':matches(Identifier,\x20AssignmentPattern,\x20RestElement,\x20ObjectPattern,\x20ArrayPattern).params'};var mustNotUseIndexedAccessTypeInFunctionParams = createEslintRule(ruleName,ruleContent,__name(function create(_0x5f208b,[_0x4ed704]){return {[':function\x20>\x20'+constants['functionParamsSelector']+'\x20TSTypeAnnotation\x20TSIndexedAccessType'](_0x3d450a){if(_0x3d450a['objectType']['type']===nodeTypes['TSTypeReference']&&isIdentifier(_0x3d450a['objectType']['typeName'])){const _0x5678ab=_0x3d450a['objectType']['typeName'];_0x4ed704['includes']['some'](_0xd92e8=>isNameMatch(_0x5678ab,_0xd92e8))&&_0x5f208b['report']({'node':getRootTSType(_0x3d450a),'messageId':ruleName});}}};},'create'),{'schema':[{'type':'object','properties':{'includes':{'type':'array','items':{'type':'string'}}}}],'defaultOptions':[{'includes':['PropertyMeta']}]});
5
+ var __defProp=Object['defineProperty'],__name=(_0x30117c,_0x47e9ee)=>__defProp(_0x30117c,'name',{'value':_0x47e9ee,'configurable':!![]});const ruleName='must-not-use-indexed-access-type-in-function-params';const ruleContent='\x0a###\x20**Must\x20not**\x20use\x20indexed\x20access\x20type\x20in\x20function\x20parameters\x0a\x0a####\x20Wrong\x0a\x0afunction\x20foo(bar:\x20baz[\x22qux\x22])\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0a####\x20Correct\x0a\x0aexport\x20function\x20foo(bar:\x20baz)\x20{\x0a\x20\x20\x20\x20return\x20waldo(bar.qux);\x0a}\x0a\x0a####\x20Why\x0a\x0aIndexed\x20access\x20types\x20in\x20function\x20parameters\x20make\x20signatures\x20harder\x20to\x20read\x20and\x20understand.\x0a',constants={'functionParamsSelector':':matches(Identifier,\x20AssignmentPattern,\x20RestElement,\x20ObjectPattern,\x20ArrayPattern).params'};var mustNotUseIndexedAccessTypeInFunctionParams = createEslintRule(ruleName,ruleContent,__name(function create(_0x1f5f4f,[_0x5133b0]){return {[':function\x20>\x20'+constants['functionParamsSelector']+'\x20TSTypeAnnotation\x20TSIndexedAccessType'](_0x4dd9e1){if(_0x4dd9e1['objectType']['type']===nodeTypes['TSTypeReference']&&isIdentifier(_0x4dd9e1['objectType']['typeName'])){const _0x23294a=_0x4dd9e1['objectType']['typeName'];_0x5133b0['includes']['some'](_0x106e5b=>isNameMatch(_0x23294a,_0x106e5b))&&_0x1f5f4f['report']({'node':getRootTSType(_0x4dd9e1),'messageId':ruleName});}}};},'create'),{'schema':[{'type':'object','properties':{'includes':{'type':'array','items':{'type':'string'}}}}],'defaultOptions':[{'includes':['PropertyMeta']}]});
6
6
 
7
7
  export { mustNotUseIndexedAccessTypeInFunctionParams as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-not-use-location-href";
2
3
  declare const mustNotUseLocationHref: ESLintUtils.RuleModule<"mustNotUseLocationHref", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNotUseLocationHref;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { isNameMatch, nodeTypes } from '@flint/infra/ast-helpers';
3
+ import { isNameMatch, nodeTypes } from '@flint/infra/analysis';
4
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0x1391e4,_0xd24ec2)=>__defProp(_0x1391e4,'name',{'value':_0xd24ec2,'configurable':!![]});const constants={'url':'https://example.com/rules/','ruleName':'must-not-use-location-href','messageIds':{'mustNotUseLocationHref':'mustNotUseLocationHref'},'meta':{'type':'problem','docs':{'description':'Must\x20not\x20use\x20location.href\x20directly'},'messages':{'mustNotUseLocationHref':'must-not-use-location-href\x0a###\x20**Must\x20not**\x20use\x20location.href.\x0a\x0a####\x20Wrong:\x0a\x0awindow.location.href\x20=\x20getFooUrl();\x0a\x0a####\x20Correct:\x0a\x0anavigate(routes.foo);\x0a\x0a####\x20Why:\x0a\x0aWe\x20standardize\x20on\x20using\x20navigation\x20functions,\x20not\x20location.href.'},'schema':[]}};function reportLocationHref(_0x35d5e6,_0x39336e){_0x39336e['report']({'node':_0x35d5e6,'messageId':constants['messageIds']['mustNotUseLocationHref']});}__name(reportLocationHref,'reportLocationHref');const createRule=ESLintUtils['RuleCreator'](_0x3d3835=>''+constants['url']+_0x3d3835),mustNotUseLocationHref=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0xdd66bf){return {'MemberExpression'(_0x2bfede){isLocationHref(_0x2bfede)&&reportLocationHref(_0x2bfede,_0xdd66bf);}};}});function isLocationHref(_0x416f4a){return _0x416f4a['property']['type']===nodeTypes['identifier']&&isNameMatch(_0x416f4a['property'],'href')&&(_0x416f4a['object']['type']===nodeTypes['identifier']&&isNameMatch(_0x416f4a['object'],'location')||_0x416f4a['object']['type']===nodeTypes['memberExpression']&&_0x416f4a['object']['object']['type']===nodeTypes['identifier']&&isNameMatch(_0x416f4a['object']['object'],'window')&&_0x416f4a['object']['property']['type']===nodeTypes['identifier']&&isNameMatch(_0x416f4a['object']['property'],'location'));}__name(isLocationHref,'isLocationHref');
6
+ var __defProp=Object['defineProperty'],__name=(_0x193918,_0x1c0b96)=>__defProp(_0x193918,'name',{'value':_0x1c0b96,'configurable':!![]});const ruleName='must-not-use-location-href';const constants={'messageIds':{'mustNotUseLocationHref':'mustNotUseLocationHref'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Must\x20not\x20use\x20location.href\x20directly'},'messages':{'mustNotUseLocationHref':'must-not-use-location-href\x0a###\x20**Must\x20not**\x20use\x20location.href.\x0a\x0a####\x20Wrong:\x0a\x0awindow.location.href\x20=\x20getFooUrl();\x0a\x0a####\x20Correct:\x0a\x0anavigate(routes.foo);\x0a\x0a####\x20Why:\x0a\x0aWe\x20standardize\x20on\x20using\x20navigation\x20functions,\x20not\x20location.href.'},'schema':[]}};function reportLocationHref(_0x374c95,_0x32da30){_0x32da30['report']({'node':_0x374c95,'messageId':constants['messageIds']['mustNotUseLocationHref']});}__name(reportLocationHref,'reportLocationHref');const createRule=ESLintUtils['RuleCreator'](_0x10e1f7=>''+url+_0x10e1f7),mustNotUseLocationHref=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x114f1f){return {'MemberExpression'(_0x1820fb){isLocationHref(_0x1820fb)&&reportLocationHref(_0x1820fb,_0x114f1f);}};}});function isLocationHref(_0x21cb1c){return _0x21cb1c['property']['type']===nodeTypes['identifier']&&isNameMatch(_0x21cb1c['property'],'href')&&(_0x21cb1c['object']['type']===nodeTypes['identifier']&&isNameMatch(_0x21cb1c['object'],'location')||_0x21cb1c['object']['type']===nodeTypes['memberExpression']&&_0x21cb1c['object']['object']['type']===nodeTypes['identifier']&&isNameMatch(_0x21cb1c['object']['object'],'window')&&_0x21cb1c['object']['property']['type']===nodeTypes['identifier']&&isNameMatch(_0x21cb1c['object']['property'],'location'));}__name(isLocationHref,'isLocationHref');
6
7
 
7
- export { mustNotUseLocationHref as default };
8
+ export { mustNotUseLocationHref as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-not-use-negation-with-enums";
2
3
  declare const mustNotUseNegationWithEnums: ESLintUtils.RuleModule<"mustNotUseNegationWithEnums", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNotUseNegationWithEnums;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { nodeTypes, isPseudoEnumType } from '@flint/infra/ast-helpers';
3
+ import { nodeTypes, isPseudoEnumType } from '@flint/infra/analysis';
4
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- const constants={'ruleName':'must-not-use-negation-with-enums','url':'https://example.com/rules/must-not-use-negation-with-enums','messageIds':{'mustNotUseNegationWithEnums':'mustNotUseNegationWithEnums'},'meta':{'type':'problem','docs':{'description':'Must\x20not\x20use\x20the\x20!\x20operator\x20with\x20enum\x20types,\x20including\x20as\x20const\x20enum-like\x20objects.'},'messages':{'mustNotUseNegationWithEnums':'must-not-use-negation-with-enums\x0a###\x20**Must\x20not**\x20use\x20the\x20\x27!\x27\x20operator\x20with\x20enum\x20types.\x0a\x0aAvoid\x20using\x20the\x20logical\x20negation\x20operator\x20`!`\x20on\x20pseudo-enum\x20objects.\x20This\x20can\x20lead\x20to\x20misleading\x20or\x20incorrect\x20logic\x20since\x20pseudo-enums\x20are\x20not\x20booleans.\x0a\x0a####\x20Wrong:\x0a\x0aconst\x20Status\x20=\x20{\x0a\x20\x20Active:\x201,\x0a\x20\x20Inactive:\x200,\x0a}\x20as\x20const;\x0a\x0aif\x20(!Status.Active)\x20{\x0a\x20\x20//\x20This\x20condition\x20will\x20never\x20trigger\x20as\x201\x20is\x20truthy.\x0a}\x0a\x0a####\x20Correct:\x0a\x0aconst\x20Status\x20=\x20{\x0a\x20\x20Active:\x201,\x0a\x20\x20Inactive:\x200,\x0a}\x20as\x20const;\x0a\x0aconst\x20isActive\x20=\x20user.status\x20===\x20Status.Active;\x0aif\x20(!isActive)\x20{\x0a\x20\x20//\x20Now\x20this\x20makes\x20sense.\x0a}\x0a\x0a####\x20Why:\x0a\x0aNegating\x20pseudo-enums\x20like\x20!Status.Active\x20coerces\x20numbers\x20to\x20booleans,\x20which\x20is\x20usually\x20not\x20intended.'},'schema':[]}},createRule=ESLintUtils['RuleCreator'](()=>constants['url']),mustNotUseNegationWithEnums=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x48198c){const _0x3fb1fc=_0x48198c['sourceCode']['parserServices'];if(!_0x3fb1fc?.['program']||!_0x3fb1fc['esTreeNodeToTSNodeMap'])return {};const _0x5882db=_0x3fb1fc['program']['getTypeChecker'](),_0x3fa370=_0x3fb1fc['esTreeNodeToTSNodeMap'];return {'UnaryExpression'(_0x52fadf){if(_0x52fadf['operator']!=='!')return;const _0x280dab=_0x3fa370['get'](_0x52fadf['argument']);if(!_0x280dab)return;if(_0x52fadf['argument']['type']===nodeTypes['memberExpression']&&_0x52fadf['argument']['property']['type']===nodeTypes['identifier']){const _0x463f94=_0x3fa370['get'](_0x52fadf['argument']['object']);if(_0x463f94){const _0x349b9b=_0x5882db['getTypeAtLocation'](_0x463f94);if(isPseudoEnumType(_0x349b9b,_0x5882db)){_0x48198c['report']({'node':_0x52fadf,'messageId':constants['messageIds']['mustNotUseNegationWithEnums']});return;}}}const _0x8fe260=_0x5882db['getTypeAtLocation'](_0x280dab);isPseudoEnumType(_0x8fe260,_0x5882db)&&_0x48198c['report']({'node':_0x52fadf,'messageId':constants['messageIds']['mustNotUseNegationWithEnums']});}};}});
6
+ const ruleName='must-not-use-negation-with-enums';const constants={'messageIds':{'mustNotUseNegationWithEnums':'mustNotUseNegationWithEnums'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Must\x20not\x20use\x20the\x20!\x20operator\x20with\x20enum\x20types,\x20including\x20as\x20const\x20enum-like\x20objects.'},'messages':{'mustNotUseNegationWithEnums':'must-not-use-negation-with-enums\x0a###\x20**Must\x20not**\x20use\x20the\x20\x27!\x27\x20operator\x20with\x20enum\x20types.\x0a\x0aAvoid\x20using\x20the\x20logical\x20negation\x20operator\x20`!`\x20on\x20pseudo-enum\x20objects.\x20This\x20can\x20lead\x20to\x20misleading\x20or\x20incorrect\x20logic\x20since\x20pseudo-enums\x20are\x20not\x20booleans.\x0a\x0a####\x20Wrong:\x0a\x0aconst\x20Status\x20=\x20{\x0a\x20\x20Active:\x201,\x0a\x20\x20Inactive:\x200,\x0a}\x20as\x20const;\x0a\x0aif\x20(!Status.Active)\x20{\x0a\x20\x20//\x20This\x20condition\x20will\x20never\x20trigger\x20as\x201\x20is\x20truthy.\x0a}\x0a\x0a####\x20Correct:\x0a\x0aconst\x20Status\x20=\x20{\x0a\x20\x20Active:\x201,\x0a\x20\x20Inactive:\x200,\x0a}\x20as\x20const;\x0a\x0aconst\x20isActive\x20=\x20user.status\x20===\x20Status.Active;\x0aif\x20(!isActive)\x20{\x0a\x20\x20//\x20Now\x20this\x20makes\x20sense.\x0a}\x0a\x0a####\x20Why:\x0a\x0aNegating\x20pseudo-enums\x20like\x20!Status.Active\x20coerces\x20numbers\x20to\x20booleans,\x20which\x20is\x20usually\x20not\x20intended.'},'schema':[]}},createRule=ESLintUtils['RuleCreator'](_0x1c5727=>''+url+_0x1c5727),mustNotUseNegationWithEnums=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x3e601e){const _0x595e0e=_0x3e601e['sourceCode']['parserServices'];if(!_0x595e0e?.['program']||!_0x595e0e['esTreeNodeToTSNodeMap'])return {};const _0x386e4e=_0x595e0e['program']['getTypeChecker'](),_0x4d632f=_0x595e0e['esTreeNodeToTSNodeMap'];return {'UnaryExpression'(_0x153d1a){if(_0x153d1a['operator']!=='!')return;const _0x2451b7=_0x4d632f['get'](_0x153d1a['argument']);if(!_0x2451b7)return;if(_0x153d1a['argument']['type']===nodeTypes['memberExpression']&&_0x153d1a['argument']['property']['type']===nodeTypes['identifier']){const _0x3c1b59=_0x4d632f['get'](_0x153d1a['argument']['object']);if(_0x3c1b59){const _0x3af603=_0x386e4e['getTypeAtLocation'](_0x3c1b59);if(isPseudoEnumType(_0x3af603,_0x386e4e)){_0x3e601e['report']({'node':_0x153d1a,'messageId':constants['messageIds']['mustNotUseNegationWithEnums']});return;}}}const _0x41cf90=_0x386e4e['getTypeAtLocation'](_0x2451b7);isPseudoEnumType(_0x41cf90,_0x386e4e)&&_0x3e601e['report']({'node':_0x153d1a,'messageId':constants['messageIds']['mustNotUseNegationWithEnums']});}};}});
6
7
 
7
- export { mustNotUseNegationWithEnums as default };
8
+ export { mustNotUseNegationWithEnums as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-not-use-null";
2
3
  declare const mustNotUseNull: ESLintUtils.RuleModule<"mustNotUseNull", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNotUseNull;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { nodeTypes } from '@flint/infra/ast-helpers';
3
+ import { nodeTypes } from '@flint/infra/analysis';
4
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- const constants={'undefinedKeyword':'undefined','unionTypeSeparator':'\x20|\x20','url':'https://example.com/rules/','ruleName':'must-not-use-null','messageIds':{'mustNotUseNull':'mustNotUseNull'},'meta':{'type':'problem','docs':{'description':'Disallow\x20use\x20of\x20`null`\x20and\x20`|\x20null`\x20in\x20TypeScript\x20types.\x20Prefer\x20`undefined`\x20and\x20optional\x20properties.','recommended':'error'},'messages':{'mustNotUseNull':'must-not-use-null\x0a\x20\x20\x20\x0a{{message}}\x0a\x0a###\x20**Must\x20not**\x20use\x20\x22null\x22\x0a\x0a####\x20Wrong\x0a\x0aif\x20(!data)\x20{\x0a\x20\x20result\x20=\x20null;\x0a\x0ainterface\x20Props\x20{\x0a\x20\x20\x20\x20foo:\x20string\x20|\x20null;\x0a}\x0a\x0a####\x20Correct\x0a\x0aif\x20(!data)\x20{\x0a\x20\x20result\x20=\x20undefined;\x0a\x0ainterface\x20Props\x20{\x0a\x20\x20\x20\x20foo?:\x20string;\x0a}\x0a\x0a####\x20Why\x0a\x0aOptional\x20operator\x20\x22?\x22\x20only\x20uses\x20undefined\x20as\x20a\x20fallback,\x20if\x20the\x20value\x20isn’t\x20provided.\x20For\x20null\x20you\x20should\x20explicitly\x20set\x20null\x20as\x20a\x20value,\x20so\x20it\x20should\x20be\x20avoided.\x0a'},'schema':[],'fixable':'code'},'errorMessageTemplates':{'literalNull':'Using\x20`null`\x20literal\x20is\x20not\x20allowed.\x20Use\x20`undefined`\x20instead.','unionNull':'Using\x20`|\x20null`\x20in\x20types\x20is\x20not\x20allowed.\x20Use\x20optional\x20property\x20`?`\x20instead.'}},createRule=ESLintUtils['RuleCreator'](_0x173b29=>''+constants['url']+_0x173b29),mustNotUseNull=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x597acd){return {'Literal'(_0x33e818){_0x33e818['value']===null&&_0x597acd['report']({'node':_0x33e818,'messageId':constants['messageIds']['mustNotUseNull'],'data':{'message':constants['errorMessageTemplates']['literalNull']},'fix'(_0x5a2438){return _0x5a2438['replaceText'](_0x33e818,constants['undefinedKeyword']);}});},'TSNullKeyword'(_0x2c8de4){const _0x271809=_0x597acd['sourceCode'],_0x2e7709=_0x2c8de4['parent'];_0x597acd['report']({'node':_0x2c8de4,'messageId':constants['messageIds']['mustNotUseNull'],'data':{'message':constants['errorMessageTemplates']['unionNull']},'fix'(_0x51db63){if(_0x2e7709?.['type']===nodeTypes['TSUnionType']){const _0x1c1bec=_0x2e7709['types'],_0x5b9929=_0x1c1bec['some'](_0x585e59=>_0x585e59['type']===nodeTypes['TSUndefinedKeyword']);if(_0x5b9929){const _0x293194=_0x1c1bec['filter'](_0xbb5c3b=>_0xbb5c3b!==_0x2c8de4),_0x1af294=_0x293194['map'](_0x18ae88=>_0x271809['getText'](_0x18ae88));return _0x51db63['replaceText'](_0x2e7709,_0x1af294['join'](constants['unionTypeSeparator']));}}return _0x51db63['replaceText'](_0x2c8de4,constants['undefinedKeyword']);}});}};}});
6
+ const ruleName='must-not-use-null';const constants={'undefinedKeyword':'undefined','unionTypeSeparator':'\x20|\x20','messageIds':{'mustNotUseNull':'mustNotUseNull'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Disallow\x20use\x20of\x20`null`\x20and\x20`|\x20null`\x20in\x20TypeScript\x20types.\x20Prefer\x20`undefined`\x20and\x20optional\x20properties.','recommended':'error'},'messages':{'mustNotUseNull':'must-not-use-null\x0a\x20\x20\x20\x0a{{message}}\x0a\x0a###\x20**Must\x20not**\x20use\x20\x22null\x22\x0a\x0a####\x20Wrong\x0a\x0aif\x20(!data)\x20{\x0a\x20\x20result\x20=\x20null;\x0a\x0ainterface\x20Props\x20{\x0a\x20\x20\x20\x20foo:\x20string\x20|\x20null;\x0a}\x0a\x0a####\x20Correct\x0a\x0aif\x20(!data)\x20{\x0a\x20\x20result\x20=\x20undefined;\x0a\x0ainterface\x20Props\x20{\x0a\x20\x20\x20\x20foo?:\x20string;\x0a}\x0a\x0a####\x20Why\x0a\x0aOptional\x20operator\x20\x22?\x22\x20only\x20uses\x20undefined\x20as\x20a\x20fallback,\x20if\x20the\x20value\x20isn’t\x20provided.\x20For\x20null\x20you\x20should\x20explicitly\x20set\x20null\x20as\x20a\x20value,\x20so\x20it\x20should\x20be\x20avoided.\x0a'},'schema':[],'fixable':'code'},'errorMessageTemplates':{'literalNull':'Using\x20`null`\x20literal\x20is\x20not\x20allowed.\x20Use\x20`undefined`\x20instead.','unionNull':'Using\x20`|\x20null`\x20in\x20types\x20is\x20not\x20allowed.\x20Use\x20optional\x20property\x20`?`\x20instead.'}},createRule=ESLintUtils['RuleCreator'](_0x960a1a=>''+url+_0x960a1a),mustNotUseNull=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x15cff2){return {'Literal'(_0x1fe471){_0x1fe471['value']===null&&_0x15cff2['report']({'node':_0x1fe471,'messageId':constants['messageIds']['mustNotUseNull'],'data':{'message':constants['errorMessageTemplates']['literalNull']},'fix'(_0x1c1b66){return _0x1c1b66['replaceText'](_0x1fe471,constants['undefinedKeyword']);}});},'TSNullKeyword'(_0x118acc){const _0x1d2b20=_0x15cff2['sourceCode'],_0x3a7d22=_0x118acc['parent'];_0x15cff2['report']({'node':_0x118acc,'messageId':constants['messageIds']['mustNotUseNull'],'data':{'message':constants['errorMessageTemplates']['unionNull']},'fix'(_0x531a5c){if(_0x3a7d22?.['type']===nodeTypes['TSUnionType']){const _0x20f100=_0x3a7d22['types'],_0x23909c=_0x20f100['some'](_0x1a9854=>_0x1a9854['type']===nodeTypes['TSUndefinedKeyword']);if(_0x23909c){const _0x275b6b=_0x20f100['filter'](_0x4e5d8f=>_0x4e5d8f!==_0x118acc),_0x3cbda1=_0x275b6b['map'](_0x2e9213=>_0x1d2b20['getText'](_0x2e9213));return _0x531a5c['replaceText'](_0x3a7d22,_0x3cbda1['join'](constants['unionTypeSeparator']));}}return _0x531a5c['replaceText'](_0x118acc,constants['undefinedKeyword']);}});}};}});
6
7
 
7
- export { mustNotUseNull as default };
8
+ export { mustNotUseNull as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-not-use-po-in-assert-functions";
2
3
  declare const mustNotUsePoInAssertFunctions: ESLintUtils.RuleModule<"mustNotUsePoInAssertFunctions", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNotUsePoInAssertFunctions;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { nodeTypes, getFunctionName } from '@flint/infra/ast-helpers';
3
+ import { nodeTypes, getFunctionName } from '@flint/infra/analysis';
4
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0x33b9fe,_0x1e8285)=>__defProp(_0x33b9fe,'name',{'value':_0x1e8285,'configurable':!![]});const constants={'url':'https://example.com/rules/','ruleName':'must-not-use-po-in-assert-functions','assertFunctionPrefix':'assert','pageObjectPattern':/Po$|PageObject$/i,'messageIds':{'mustNotUsePoInAssertFunctions':'mustNotUsePoInAssertFunctions'},'meta':{'type':'problem','docs':{'description':'Assert\x20functions\x20must\x20not\x20accept\x20PageObject\x20parameters.\x20Use\x20`page`\x20instead.','recommended':'error'},'messages':{'mustNotUsePoInAssertFunctions':'must-not-use-po-in-assert-functions\x0a###\x20**Must\x20not**\x20use\x20PageObject\x20parameters\x20in\x20assert\x20functions\x0a\x0aAlways\x20pass\x20\x27page\x27\x20instead.\x0a\x0a####\x20Wrong:\x0a\x0aexport\x20function\x20assertFoo(fooPo:\x20LoginPo)\x20{\x20…\x20}\x0a\x0a####\x20Correct:\x0a\x0aexport\x20function\x20assertFoo(page)\x20{\x20…\x20}\x0a\x0a####\x20Why:\x0a\x0aWe\x20standardize\x20on\x20using\x20page\x20as\x20a\x20parameter\x20in\x20assert\x20functions,\x20instead\x20of\x20passing\x20a\x20page\x20object\x20(po).\x20Assert\x20functions\x20should\x20stay\x20independent\x20from\x20page\x20object\x20implementations.'},'schema':[]}},createRule=ESLintUtils['RuleCreator'](_0x379c77=>''+constants['url']+_0x379c77);function isPoParamName(_0x47d33c){return constants['pageObjectPattern']['test'](_0x47d33c);}__name(isPoParamName,'isPoParamName');function isPoParamType(_0x3f647a){if(!_0x3f647a['typeAnnotation'])return ![];if(_0x3f647a['typeAnnotation']['type']!==nodeTypes['TSTypeAnnotation'])return ![];if(!('typeAnnotation'in _0x3f647a['typeAnnotation']))return ![];return checkType(_0x3f647a['typeAnnotation']['typeAnnotation']);}__name(isPoParamType,'isPoParamType');function checkType(_0x4c1538){switch(_0x4c1538['type']){case nodeTypes['TSTypeReference']:if('typeName'in _0x4c1538&&_0x4c1538['typeName']['type']===nodeTypes['identifier'])return constants['pageObjectPattern']['test'](_0x4c1538['typeName']['name']);return ![];case nodeTypes['TSUnionType']:case nodeTypes['TSIntersectionType']:return _0x4c1538['types']['some'](checkType);case nodeTypes['TSArrayType']:return checkType(_0x4c1538['elementType']);default:return ![];}}__name(checkType,'checkType');function checkParam(_0x2c1366,_0x3f4232){if(!_0x3f4232)return;const _0x255a06=__name(_0x3dbec3=>{(isPoParamName(_0x3dbec3['name'])||isPoParamType(_0x3dbec3))&&_0x2c1366['report']({'node':_0x3dbec3,'messageId':constants['messageIds']['mustNotUsePoInAssertFunctions']});},'reportIfPo');switch(_0x3f4232['type']){case nodeTypes['identifier']:_0x255a06(_0x3f4232);break;case nodeTypes['assignmentPattern']:checkParam(_0x2c1366,_0x3f4232['left']);break;case nodeTypes['restElement']:checkParam(_0x2c1366,_0x3f4232['argument']);break;case nodeTypes['objectPattern']:if(_0x3f4232['typeAnnotation']){const _0x1c4c97=_0x3f4232['typeAnnotation']['typeAnnotation'];checkType(_0x1c4c97)&&_0x2c1366['report']({'node':_0x3f4232,'messageId':constants['messageIds']['mustNotUsePoInAssertFunctions']});}_0x3f4232['properties']['forEach'](_0x376268=>{if(_0x376268['type']===nodeTypes['property']&&_0x376268['value'])checkParam(_0x2c1366,_0x376268['value']);if(_0x376268['type']===nodeTypes['restElement'])checkParam(_0x2c1366,_0x376268['argument']);});break;case nodeTypes['arrayPattern']:_0x3f4232['elements']['forEach'](_0x45a360=>{if(_0x45a360)checkParam(_0x2c1366,_0x45a360);});break;default:break;}}__name(checkParam,'checkParam');function checkParams(_0x218595,_0x376d73){for(const _0x13d590 of _0x218595){checkParam(_0x376d73,_0x13d590);}}__name(checkParams,'checkParams');function checkAssertFunctionParams(_0xb8aa45,_0x283279){const _0x486c3a=getFunctionName(_0xb8aa45);_0x486c3a?.['startsWith'](constants['assertFunctionPrefix'])&&checkParams(_0xb8aa45['params'],_0x283279);}__name(checkAssertFunctionParams,'checkAssertFunctionParams');const mustNotUsePoInAssertFunctions=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x3ad811){return {'FunctionDeclaration'(_0x1b5e7f){_0x1b5e7f['id']?.['name']?.['startsWith'](constants['assertFunctionPrefix'])&&checkParams(_0x1b5e7f['params'],_0x3ad811);},'FunctionExpression'(_0x5a4f62){checkAssertFunctionParams(_0x5a4f62,_0x3ad811);},'ArrowFunctionExpression'(_0x4c7566){checkAssertFunctionParams(_0x4c7566,_0x3ad811);}};}});
6
+ var __defProp=Object['defineProperty'],__name=(_0x406640,_0x454474)=>__defProp(_0x406640,'name',{'value':_0x454474,'configurable':!![]});const ruleName='must-not-use-po-in-assert-functions';const constants={'assertFunctionPrefix':'assert','pageObjectPattern':/Po$|PageObject$/i,'messageIds':{'mustNotUsePoInAssertFunctions':'mustNotUsePoInAssertFunctions'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Assert\x20functions\x20must\x20not\x20accept\x20PageObject\x20parameters.\x20Use\x20`page`\x20instead.','recommended':'error'},'messages':{'mustNotUsePoInAssertFunctions':'must-not-use-po-in-assert-functions\x0a###\x20**Must\x20not**\x20use\x20PageObject\x20parameters\x20in\x20assert\x20functions\x0a\x0aAlways\x20pass\x20\x27page\x27\x20instead.\x0a\x0a####\x20Wrong:\x0a\x0aexport\x20function\x20assertFoo(fooPo:\x20LoginPo)\x20{\x20…\x20}\x0a\x0a####\x20Correct:\x0a\x0aexport\x20function\x20assertFoo(page)\x20{\x20…\x20}\x0a\x0a####\x20Why:\x0a\x0aWe\x20standardize\x20on\x20using\x20page\x20as\x20a\x20parameter\x20in\x20assert\x20functions,\x20instead\x20of\x20passing\x20a\x20page\x20object\x20(po).\x20Assert\x20functions\x20should\x20stay\x20independent\x20from\x20page\x20object\x20implementations.'},'schema':[]}},createRule=ESLintUtils['RuleCreator'](_0x138d0c=>''+url+_0x138d0c);function isPoParamName(_0xb0444d){return constants['pageObjectPattern']['test'](_0xb0444d);}__name(isPoParamName,'isPoParamName');function isPoParamType(_0x2bf7c6){if(!_0x2bf7c6['typeAnnotation'])return ![];if(_0x2bf7c6['typeAnnotation']['type']!==nodeTypes['TSTypeAnnotation'])return ![];if(!('typeAnnotation'in _0x2bf7c6['typeAnnotation']))return ![];return checkType(_0x2bf7c6['typeAnnotation']['typeAnnotation']);}__name(isPoParamType,'isPoParamType');function checkType(_0x589016){switch(_0x589016['type']){case nodeTypes['TSTypeReference']:if('typeName'in _0x589016&&_0x589016['typeName']['type']===nodeTypes['identifier'])return constants['pageObjectPattern']['test'](_0x589016['typeName']['name']);return ![];case nodeTypes['TSUnionType']:case nodeTypes['TSIntersectionType']:return _0x589016['types']['some'](checkType);case nodeTypes['TSArrayType']:return checkType(_0x589016['elementType']);default:return ![];}}__name(checkType,'checkType');function checkParam(_0xef641b,_0x3a5d2c){if(!_0x3a5d2c)return;const _0x190a41=__name(_0xbadae2=>{(isPoParamName(_0xbadae2['name'])||isPoParamType(_0xbadae2))&&_0xef641b['report']({'node':_0xbadae2,'messageId':constants['messageIds']['mustNotUsePoInAssertFunctions']});},'reportIfPo');switch(_0x3a5d2c['type']){case nodeTypes['identifier']:_0x190a41(_0x3a5d2c);break;case nodeTypes['assignmentPattern']:checkParam(_0xef641b,_0x3a5d2c['left']);break;case nodeTypes['restElement']:checkParam(_0xef641b,_0x3a5d2c['argument']);break;case nodeTypes['objectPattern']:if(_0x3a5d2c['typeAnnotation']){const _0x15a922=_0x3a5d2c['typeAnnotation']['typeAnnotation'];checkType(_0x15a922)&&_0xef641b['report']({'node':_0x3a5d2c,'messageId':constants['messageIds']['mustNotUsePoInAssertFunctions']});}_0x3a5d2c['properties']['forEach'](_0xf57ad4=>{if(_0xf57ad4['type']===nodeTypes['property']&&_0xf57ad4['value'])checkParam(_0xef641b,_0xf57ad4['value']);if(_0xf57ad4['type']===nodeTypes['restElement'])checkParam(_0xef641b,_0xf57ad4['argument']);});break;case nodeTypes['arrayPattern']:_0x3a5d2c['elements']['forEach'](_0x58daed=>{if(_0x58daed)checkParam(_0xef641b,_0x58daed);});break;default:break;}}__name(checkParam,'checkParam');function checkParams(_0x524911,_0x375a8c){for(const _0xd6a0e7 of _0x524911){checkParam(_0x375a8c,_0xd6a0e7);}}__name(checkParams,'checkParams');function checkAssertFunctionParams(_0x23c399,_0x382e10){const _0x5c937a=getFunctionName(_0x23c399);_0x5c937a?.['startsWith'](constants['assertFunctionPrefix'])&&checkParams(_0x23c399['params'],_0x382e10);}__name(checkAssertFunctionParams,'checkAssertFunctionParams');const mustNotUsePoInAssertFunctions=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x3ad781){return {'FunctionDeclaration'(_0x160e48){_0x160e48['id']?.['name']?.['startsWith'](constants['assertFunctionPrefix'])&&checkParams(_0x160e48['params'],_0x3ad781);},'FunctionExpression'(_0x30d5a5){checkAssertFunctionParams(_0x30d5a5,_0x3ad781);},'ArrowFunctionExpression'(_0x7476ac){checkAssertFunctionParams(_0x7476ac,_0x3ad781);}};}});
6
7
 
7
- export { mustNotUsePoInAssertFunctions as default };
8
+ export { mustNotUsePoInAssertFunctions as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-not-use-redundant-string";
2
3
  declare const mustNotUseRedundantString: ESLintUtils.RuleModule<"mustNotUseRedundantString", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNotUseRedundantString;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { nodeTypes, isNameMatch } from '@flint/infra/ast-helpers';
3
+ import { nodeTypes, isNameMatch } from '@flint/infra/analysis';
4
+ import { url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- const constants={'url':'https://example.com/rules/','ruleName':'must-not-use-redundant-string','messageIds':{'mustNotUseRedundantString':'mustNotUseRedundantString'},'meta':{'type':'suggestion','docs':{'description':'Redundant\x20use\x20of\x20String()\x20for\x20already\x20string-typed\x20value.'},'messages':{'mustNotUseRedundantString':'must-not-use-redundant-string\x0aRedundant\x20use\x20of\x20String()\x20for\x20already\x20string-typed\x20value\x20\x27{{name}}\x27.\x0a\x0a###\x20**Must\x20not**\x20use\x20redundant\x20String().\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0a####\x20Wrong:\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0afunction\x20foo(bar:\x20string)\x20{\x0a\x20\x20\x20\x20const\x20baz\x20=\x20String(bar);\x0a\x20\x20\x20\x20…\x0a}\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0a####\x20Correct:\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0afunction\x20foo(bar:\x20string)\x20{\x0a\x20\x20\x20\x20…\x0a}\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0a####\x20Why:\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x0aIf\x20the\x20type\x20of\x20a\x20property\x20is\x20a\x20string,\x20it\x20is\x20expected\x20that\x20it\x20contains\x20a\x20string,\x20therefore\x20no\x20need\x20to\x20convert\x20it\x20using\x20String().\x20If\x20there\x20is\x20a\x20point\x20in\x20conversion,\x20then\x20the\x20type\x20shouldn’t\x20be\x20string\x20in\x20the\x20first\x20place.'},'schema':[],'fixable':'code'},'calleeName':'String'},createRule=ESLintUtils['RuleCreator'](_0xc3e87e=>''+constants['url']+_0xc3e87e),mustNotUseRedundantString=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x493e88){const _0x324bc7=_0x493e88['sourceCode']['parserServices'];if(!_0x324bc7?.['program']||!_0x324bc7['esTreeNodeToTSNodeMap'])return {};const _0x69af10=_0x324bc7['program']['getTypeChecker']();return {'CallExpression'(_0x243534){if(_0x243534['callee']['type']===nodeTypes['identifier']&&isNameMatch(_0x243534['callee'],constants['calleeName'])&&_0x243534['arguments']['length']===-0xec1+0x11*0x14+0xd6e&&_0x243534['arguments'][0x6*0x676+0x20ed*-0x1+-0xd*0x73]){const _0x58ab74=_0x243534['arguments'][0x8bb+-0x872*-0x2+-0x199f],_0x7fcbcb=_0x324bc7['esTreeNodeToTSNodeMap']?.['get'](_0x58ab74);if(!_0x7fcbcb)return;const _0x3ca378=_0x69af10['getTypeAtLocation'](_0x7fcbcb),_0x33211c=_0x69af10['getStringType']();if(_0x69af10['isTypeAssignableTo'](_0x3ca378,_0x33211c)){const _0xce5b8e=_0x493e88['sourceCode'];_0x493e88['report']({'node':_0x243534,'messageId':constants['messageIds']['mustNotUseRedundantString'],'data':{'name':_0xce5b8e['getText'](_0x58ab74)},'fix'(_0x347e59){const _0x33b3dc=_0xce5b8e['getText'](_0x58ab74);return _0x347e59['replaceText'](_0x243534,_0x33b3dc);}});}}}};}});
6
+ const ruleName='must-not-use-redundant-string';const constants={'messageIds':{'mustNotUseRedundantString':'mustNotUseRedundantString'},'meta':{'type':'suggestion','docs':{'description':'Redundant\x20use\x20of\x20String()\x20for\x20already\x20string-typed\x20value.'},'messages':{'mustNotUseRedundantString':'must-not-use-redundant-string\x0aRedundant\x20use\x20of\x20String()\x20for\x20already\x20string-typed\x20value\x20\x27{{name}}\x27.\x0a\x0a###\x20**Must\x20not**\x20use\x20redundant\x20String().\x0a\x0a####\x20Wrong:\x0a\x0afunction\x20foo(bar:\x20string)\x20{\x0a\x20\x20\x20\x20const\x20baz\x20=\x20String(bar);\x0a\x20\x20\x20\x20…\x0a}\x0a\x0a####\x20Correct:\x0a\x0afunction\x20foo(bar:\x20string)\x20{\x0a\x20\x20\x20\x20…\x0a}\x0a\x0a####\x20Why:\x0a\x0aIf\x20the\x20type\x20of\x20a\x20property\x20is\x20a\x20string,\x20it\x20is\x20expected\x20that\x20it\x20contains\x20a\x20string,\x20therefore\x20no\x20need\x20to\x20convert\x20it\x20using\x20String().\x20If\x20there\x20is\x20a\x20point\x20in\x20conversion,\x20then\x20the\x20type\x20shouldn’t\x20be\x20string\x20in\x20the\x20first\x20place.'},'schema':[],'fixable':'code'},'calleeName':'String'},createRule=ESLintUtils['RuleCreator'](_0x3201cf=>''+url+_0x3201cf),mustNotUseRedundantString=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x237b3b){const _0x5cc463=_0x237b3b['sourceCode']['parserServices'];if(!_0x5cc463?.['program']||!_0x5cc463['esTreeNodeToTSNodeMap'])return {};const _0x489e49=_0x5cc463['program']['getTypeChecker']();return {'CallExpression'(_0xf0f1db){if(_0xf0f1db['callee']['type']===nodeTypes['identifier']&&isNameMatch(_0xf0f1db['callee'],constants['calleeName'])&&_0xf0f1db['arguments']['length']===0x25*0x7+0x182e+0x2*-0xc98&&_0xf0f1db['arguments'][-0xb*-0x15d+0x22a1+0x634*-0x8]){const _0x5ecb2b=_0xf0f1db['arguments'][0x2a7*-0x8+0x29*-0xca+0x3592],_0x52c33d=_0x5cc463['esTreeNodeToTSNodeMap']?.['get'](_0x5ecb2b);if(!_0x52c33d)return;const _0x409608=_0x489e49['getTypeAtLocation'](_0x52c33d),_0x146c7e=_0x489e49['getStringType']();if(_0x489e49['isTypeAssignableTo'](_0x409608,_0x146c7e)){const _0x4c3c1a=_0x237b3b['sourceCode'];_0x237b3b['report']({'node':_0xf0f1db,'messageId':constants['messageIds']['mustNotUseRedundantString'],'data':{'name':_0x4c3c1a['getText'](_0x5ecb2b)},'fix'(_0x461f35){const _0x21ba6e=_0x4c3c1a['getText'](_0x5ecb2b);return _0x461f35['replaceText'](_0xf0f1db,_0x21ba6e);}});}}}};}});
6
7
 
7
- export { mustNotUseRedundantString as default };
8
+ export { mustNotUseRedundantString as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-not-use-ternary-operator-for-complicated-conditions";
2
3
  declare const mustNotUseTernaryOperatorForComplicatedConditions: ESLintUtils.RuleModule<"mustNotUseTernaryOperatorForComplicatedConditions", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustNotUseTernaryOperatorForComplicatedConditions;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { nodeTypes, getLineDistance, isJSXNode } from '@flint/infra/ast-helpers';
3
+ import { nodeTypes, getLineDistance, isJSXNode } from '@flint/infra/analysis';
4
+ import { url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0x4a9c07,_0x4bd564)=>__defProp(_0x4a9c07,'name',{'value':_0x4bd564,'configurable':!![]});const constants={'url':'https://example.com/rules/','ruleName':'must-not-use-ternary-operator-for-complicated-conditions','messageIds':{'mustNotUseTernaryOperatorForComplicatedConditions':'mustNotUseTernaryOperatorForComplicatedConditions'},'meta':{'type':'suggestion','docs':{'description':'Disallow\x20the\x20use\x20of\x20ternary\x20operator\x20for\x20complicated\x20conditions.'},'messages':{'mustNotUseTernaryOperatorForComplicatedConditions':'must-not-use-ternary-operator-for-complicated-conditions\x0a###\x20**Must\x20not**\x20use\x20\x22?\x22\x20for\x20complicated\x20conditions.\x0a\x0a####\x20Wrong:\x0a\x0aconst\x20foo\x20=\x20bar()\x0a\x20\x20\x20\x20?\x20baz()\x0a\x20\x20\x20\x20:\x20[\x0a\x20\x20\x20\x20\x20\x20\x20\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20qux:\x20quux,\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20corge:\x20grault,\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20garply:\x20waldo,\x0a\x20\x20\x20\x20\x20\x20\x20\x20},\x0a\x20\x20\x20\x20];\x0a\x0a####\x20Correct:\x0a\x0aif(bar()){\x0a\x20\x20\x20\x20…\x0a}\x20else{\x0a\x20\x20\x20\x20…\x0a}\x0a\x0a####\x20Why:\x0a\x0aTernary\x20operators\x20are\x20useful\x20for\x20simple,\x20short\x20conditions,\x20but\x20when\x20they\x20involve\x20multiple\x20operations\x20or\x20complex\x20structures,\x20they\x20can\x20make\x20the\x20code\x20harder\x20to\x20understand\x20and\x20maintain.'},'schema':[]},'limits':{'maxObjectPropertiesSimple':0x2,'maxArrayElementsSimple':0x2,'maxFunctionArgumentsSimple':0x3,'maxArrowParamsSimple':0x2}},createRule=ESLintUtils['RuleCreator'](_0x2b0cac=>''+constants['url']+_0x2b0cac);function isComplexArrowFunction(_0x280729){let _0x160094=![];_0x280729['params']['length']>constants['limits']['maxArrowParamsSimple']&&(_0x160094=!![]);_0x280729['body']['type']===nodeTypes['callExpression']&&_0x280729['body']['arguments']['length']>constants['limits']['maxFunctionArgumentsSimple']&&(_0x160094=!![]);if(_0x280729['body']['type']===nodeTypes['blockStatement'])_0x160094=!![];return _0x160094;}__name(isComplexArrowFunction,'isComplexArrowFunction');function isComplexExpression(_0x1fbaf3){if(!_0x1fbaf3)return ![];switch(_0x1fbaf3['type']){case nodeTypes['objectExpression']:return _0x1fbaf3['properties']['length']>constants['limits']['maxObjectPropertiesSimple'];case nodeTypes['arrayExpression']:return _0x1fbaf3['elements']['length']>constants['limits']['maxArrayElementsSimple']||_0x1fbaf3['elements']['some'](_0x1852bf=>_0x1852bf&&_0x1852bf['type']===nodeTypes['objectExpression']);case nodeTypes['callExpression']:case nodeTypes['newExpression']:return _0x1fbaf3['arguments']['length']>constants['limits']['maxFunctionArgumentsSimple'];case nodeTypes['conditionalExpression']:return !![];case nodeTypes['arrowFunctionExpression']:return isComplexArrowFunction(_0x1fbaf3);case nodeTypes['functionExpression']:return !![];default:return ![];}}__name(isComplexExpression,'isComplexExpression');function isMultiLineExpression(_0x220313){return getLineDistance(_0x220313,_0x220313)!==-0x1*-0x1a21+0x5*0x4b2+0x2eb*-0x11;}__name(isMultiLineExpression,'isMultiLineExpression');const mustNotUseTernaryOperatorForComplicatedConditions=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x4c08c1){return {[nodeTypes['conditionalExpression']](_0xf58089){if(isJSXNode(_0xf58089['consequent'])||isJSXNode(_0xf58089['alternate']))return;const _0x2d8088=isComplexExpression(_0xf58089['consequent']),_0x40c36a=isComplexExpression(_0xf58089['alternate']),_0x39a833=isMultiLineExpression(_0xf58089['consequent']),_0x3e6eae=isMultiLineExpression(_0xf58089['alternate']);(_0x2d8088||_0x40c36a||_0x39a833||_0x3e6eae)&&_0x4c08c1['report']({'node':_0xf58089,'messageId':constants['messageIds']['mustNotUseTernaryOperatorForComplicatedConditions']});}};}});
6
+ var __defProp=Object['defineProperty'],__name=(_0x3f6c9b,_0x57eb72)=>__defProp(_0x3f6c9b,'name',{'value':_0x57eb72,'configurable':!![]});const ruleName='must-not-use-ternary-operator-for-complicated-conditions';const constants={'messageIds':{'mustNotUseTernaryOperatorForComplicatedConditions':'mustNotUseTernaryOperatorForComplicatedConditions'},'meta':{'type':'suggestion','docs':{'description':'Disallow\x20the\x20use\x20of\x20ternary\x20operator\x20for\x20complicated\x20conditions.'},'messages':{'mustNotUseTernaryOperatorForComplicatedConditions':'must-not-use-ternary-operator-for-complicated-conditions\x0a###\x20**Must\x20not**\x20use\x20\x22?\x22\x20for\x20complicated\x20conditions.\x0a\x0a####\x20Wrong:\x0a\x0aconst\x20foo\x20=\x20bar()\x0a\x20\x20\x20\x20?\x20baz()\x0a\x20\x20\x20\x20:\x20[\x0a\x20\x20\x20\x20\x20\x20\x20\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20qux:\x20quux,\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20corge:\x20grault,\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20garply:\x20waldo,\x0a\x20\x20\x20\x20\x20\x20\x20\x20},\x0a\x20\x20\x20\x20];\x0a\x0a####\x20Correct:\x0a\x0aif(bar()){\x0a\x20\x20\x20\x20…\x0a}\x20else{\x0a\x20\x20\x20\x20…\x0a}\x0a\x0a####\x20Why:\x0a\x0aTernary\x20operators\x20are\x20useful\x20for\x20simple,\x20short\x20conditions,\x20but\x20when\x20they\x20involve\x20multiple\x20operations\x20or\x20complex\x20structures,\x20they\x20can\x20make\x20the\x20code\x20harder\x20to\x20understand\x20and\x20maintain.'},'schema':[]},'limits':{'maxObjectPropertiesSimple':0x2,'maxArrayElementsSimple':0x2,'maxFunctionArgumentsSimple':0x3,'maxArrowParamsSimple':0x2}},createRule=ESLintUtils['RuleCreator'](_0x538dd3=>''+url+_0x538dd3);function isComplexArrowFunction(_0x1fddbf){let _0x8187a7=![];_0x1fddbf['params']['length']>constants['limits']['maxArrowParamsSimple']&&(_0x8187a7=!![]);_0x1fddbf['body']['type']===nodeTypes['callExpression']&&_0x1fddbf['body']['arguments']['length']>constants['limits']['maxFunctionArgumentsSimple']&&(_0x8187a7=!![]);if(_0x1fddbf['body']['type']===nodeTypes['blockStatement'])_0x8187a7=!![];return _0x8187a7;}__name(isComplexArrowFunction,'isComplexArrowFunction');function isComplexExpression(_0x5d1bc4){if(!_0x5d1bc4)return ![];switch(_0x5d1bc4['type']){case nodeTypes['objectExpression']:return _0x5d1bc4['properties']['length']>constants['limits']['maxObjectPropertiesSimple'];case nodeTypes['arrayExpression']:return _0x5d1bc4['elements']['length']>constants['limits']['maxArrayElementsSimple']||_0x5d1bc4['elements']['some'](_0x47d2e4=>_0x47d2e4&&_0x47d2e4['type']===nodeTypes['objectExpression']);case nodeTypes['callExpression']:case nodeTypes['newExpression']:return _0x5d1bc4['arguments']['length']>constants['limits']['maxFunctionArgumentsSimple'];case nodeTypes['conditionalExpression']:return !![];case nodeTypes['arrowFunctionExpression']:return isComplexArrowFunction(_0x5d1bc4);case nodeTypes['functionExpression']:return !![];default:return ![];}}__name(isComplexExpression,'isComplexExpression');function isMultiLineExpression(_0x51515f){return getLineDistance(_0x51515f,_0x51515f)!==0xc62+-0x10df+0x47d;}__name(isMultiLineExpression,'isMultiLineExpression');const mustNotUseTernaryOperatorForComplicatedConditions=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x26619f){return {[nodeTypes['conditionalExpression']](_0x17f86b){if(isJSXNode(_0x17f86b['consequent'])||isJSXNode(_0x17f86b['alternate']))return;const _0x16e29a=isComplexExpression(_0x17f86b['consequent']),_0x54f5fc=isComplexExpression(_0x17f86b['alternate']),_0x47ccd5=isMultiLineExpression(_0x17f86b['consequent']),_0x565ef2=isMultiLineExpression(_0x17f86b['alternate']);(_0x16e29a||_0x54f5fc||_0x47ccd5||_0x565ef2)&&_0x26619f['report']({'node':_0x17f86b,'messageId':constants['messageIds']['mustNotUseTernaryOperatorForComplicatedConditions']});}};}});
6
7
 
7
- export { mustNotUseTernaryOperatorForComplicatedConditions as default };
8
+ export { mustNotUseTernaryOperatorForComplicatedConditions as default, ruleName };
@@ -1,4 +1,5 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-put-empty-line";
2
3
  type Options = [
3
4
  {
4
5
  checktypes?: string[];
@@ -1,8 +1,9 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { nodeTypes, isMethodFunction } from '@flint/infra/ast-helpers';
3
+ import { nodeTypes, isMethodFunction } from '@flint/infra/analysis';
4
4
  import { caseTransitionBoundary } from '@flint/infra/constants/rules-regex';
5
+ import { url } from '@flint/infra/constants/rules-meta';
5
6
 
6
- var __defProp=Object['defineProperty'],__name=(_0x2520c9,_0x11db30)=>__defProp(_0x2520c9,'name',{'value':_0x11db30,'configurable':!![]});const constants={'ruleName':'must-put-empty-line','url':'https://example.com/rules/','meta':{'type':'layout','docs':{'description':'Enforce\x20empty\x20lines\x20above\x20and\x20below\x20control\x20structures\x20and\x20functions'},'messages':{'emptyLineRequired':'must-put-empty-line\x0aYou\x20must\x20always\x20put\x20an\x20empty\x20line\x20{{position}}\x20{{node}}\x20for\x20better\x20code\x20readability.\x0a\x0a###\x20**Must**\x20put\x20empty\x20line\x20above\x20and\x20below\x20function,\x20if,\x20switch,\x20for\x20i,\x20try\x20and\x20semantic\x20code\x20blocks.\x0a\x0a####\x20Wrong\x0a\x0aconst\x20foo\x20=\x20bar();\x0aif(condition()){\x0a\x20\x20\x20\x20foo();\x0a}\x0a\x0afunction\x20foo()\x20{\x0a\x20\x20\x20\x20…\x0a}\x0afunction\x20bar()\x20{\x0a\x20\x20\x20\x20…\x0a}\x0a\x0a####\x20Correct\x0a\x0aconst\x20foo\x20=\x20bar();\x0a\x0aif(condition()){\x0a\x20\x20\x20\x20foo();\x0a}\x0a\x0afunction\x20foo()\x20{\x0a\x20\x20\x20…\x0a}\x0a\x0afunction\x20bar()\x20{\x0a\x20\x20\x20…\x0a}\x0a\x0a####\x20Why\x0a\x0aEmpty\x20lines\x20around\x20control\x20structures\x20and\x20functions\x20make\x20the\x20code\x20easier\x20to\x20read\x20and\x20maintain.'},'schema':[{'type':'object','properties':{'checktypes':{'type':'array','items':{'type':'string'}}},'additionalProperties':![]}],'fixable':'whitespace'},'format':{'empty':'','newLine':'\x0a','doubleNewLine':'\x0a\x0a','space':'\x20','closeBrace':'}'},'regex':{'indentation':/^\s*/},'messages':{'positions':{'above':'above','below':'below'},'ids':{'emptyLineRequired':'emptyLineRequired'}},'sourceCode':{'tokenOptions':{'includeComments':!![]}},'rule':{'lineDistances':{'adjacent':0x1}}},createRule=ESLintUtils['RuleCreator'](_0x38c2fd=>''+constants['url']+_0x38c2fd),defaultChecktypes=[nodeTypes['functionDeclaration'],nodeTypes['ifStatement'],nodeTypes['switchStatement'],nodeTypes['forStatement'],nodeTypes['whileStatement'],nodeTypes['doWhileStatement'],nodeTypes['forInStatement'],nodeTypes['forOfStatement'],nodeTypes['tryStatement'],nodeTypes['arrowFunctionExpression'],nodeTypes['functionExpression'],nodeTypes['methodDefinition'],nodeTypes['classDeclaration'],nodeTypes['variableDeclaration']];function formatNodeType(_0x12b31c){return _0x12b31c['replace'](caseTransitionBoundary,'\x20')['trim']()['toLowerCase']();}__name(formatNodeType,'formatNodeType');function getNodeIndent(_0xb63329,_0x25db97){const _0x16ddca=constants['regex']['indentation']['exec'](_0x25db97['getText'](_0xb63329));return _0x16ddca?_0x16ddca[-0x7*-0x3b8+-0x1c27+0x21f*0x1]:constants['format']['empty'];}__name(getNodeIndent,'getNodeIndent');function createFix(_0x4612de,_0x15fb27,_0xeebd03,_0x2f816f,_0x560831,_0x3213d0){const _0x39dc50=_0x2f816f+constants['format']['doubleNewLine']+_0x560831+_0x3213d0['join'](constants['format']['newLine']);return _0x4612de['replaceTextRange']([_0x15fb27,_0xeebd03],_0x39dc50);}__name(createFix,'createFix');function checkEmptyLineBelow(_0x2a45bf,_0x510289,_0x71ff76){const _0x570e8f=_0x71ff76['getTokenAfter'](_0x2a45bf,constants['sourceCode']['tokenOptions']);if(!_0x570e8f||_0x570e8f['value']===constants['format']['closeBrace'])return;const _0x4a60cf=_0x2a45bf['loc']['end']['line'],_0xbd0922=_0x570e8f['loc']['start']['line'],_0x4b04e6=_0xbd0922-_0x4a60cf;if(_0x4b04e6===constants['rule']['lineDistances']['adjacent']){const _0x184915=getNodeIndent(_0x2a45bf,_0x71ff76),_0x57926d=_0x71ff76['getText']()['slice'](_0x2a45bf['range'][0x1166+-0x2f2+-0xe73],_0x570e8f['range'][-0x1*-0x1d55+-0x499+0x2*-0xc5e]),[_0xf1e5b1=constants['format']['empty'],..._0x5a72ca]=_0x57926d['split'](constants['format']['newLine']);_0x510289['report']({'node':_0x2a45bf,'messageId':constants['messages']['ids']['emptyLineRequired'],'data':{'position':constants['messages']['positions']['below'],'node':formatNodeType(_0x2a45bf['type'])},'fix':__name(_0x1b0e77=>createFix(_0x1b0e77,_0x2a45bf['range'][-0x166f+-0x1b5b+0x31cb],_0x570e8f['range'][-0x9c0+-0x13e7+0x1da7],_0xf1e5b1,_0x184915,_0x5a72ca),'fix')});}}__name(checkEmptyLineBelow,'checkEmptyLineBelow');function checkEmptyLineAbove(_0x27ee33,_0x573cd6,_0x48be99,_0x15184e,_0x1135f0){const _0x1a819c=_0x27ee33['type']===nodeTypes['methodDefinition']&&_0x27ee33['parent']?.['type']===nodeTypes['classBody'];let _0x14392c;_0x1a819c?_0x14392c=_0x48be99['indexOf'](_0x27ee33):_0x14392c=_0x573cd6['findIndex'](_0x588666=>_0x588666===_0x27ee33);let _0x1732ea;_0x14392c>0x26b9*0x1+0xe*-0x2ca+-0x1*-0x53?_0x1a819c?_0x1732ea=_0x48be99[_0x14392c-(-0x7f*0x1a+-0x4ba+0x11a1)]:_0x1732ea=_0x573cd6[_0x14392c-(0x329*0xc+0x62c+-0x2c17*0x1)]:_0x1732ea=void(-0x1dc9+-0x8e*-0x17+0x1107);if(!_0x1732ea)return;const _0x178ebb=_0x1732ea['loc']['end']['line'],_0x32558b=_0x27ee33['loc']['start']['line'],_0x4fde9a=_0x32558b-_0x178ebb;if(_0x4fde9a===constants['rule']['lineDistances']['adjacent']){let _0x2b2799;_0x1a819c?_0x2b2799=getNodeIndent(_0x27ee33['parent']?.['parent']||_0x27ee33,_0x1135f0):_0x2b2799=getNodeIndent(_0x27ee33,_0x1135f0);const _0x23e330=_0x1135f0['getText']()['slice'](_0x1732ea['range'][-0xea3+-0x228c+0x3130],_0x27ee33['range'][0x1*-0x1676+-0xa54*-0x2+0x2a*0xb]),[_0x30c106=constants['format']['empty'],..._0x25d153]=_0x23e330['split'](constants['format']['newLine']);_0x15184e['report']({'node':_0x27ee33,'messageId':constants['messages']['ids']['emptyLineRequired'],'data':{'position':constants['messages']['positions']['above'],'node':formatNodeType(_0x27ee33['type'])},'fix':__name(_0x1d6683=>createFix(_0x1d6683,_0x1732ea['range'][-0x2*0x731+0xe0*-0x1f+0x2983],_0x27ee33['range'][0x1974+-0x243a+0xac6],_0x30c106,_0x2b2799,_0x25d153),'fix')});}}__name(checkEmptyLineAbove,'checkEmptyLineAbove');function checkAround(_0x2bfa22,_0x32326a,_0xf1801e,_0x11088b=[],_0x175d3d=[]){checkEmptyLineAbove(_0x2bfa22,_0x11088b,_0x175d3d,_0x32326a,_0xf1801e),checkEmptyLineBelow(_0x2bfa22,_0x32326a,_0xf1801e);}__name(checkAround,'checkAround');function isFunctionOrArrowType(_0x521179){return _0x521179===nodeTypes['functionExpression']||_0x521179===nodeTypes['arrowFunctionExpression'];}__name(isFunctionOrArrowType,'isFunctionOrArrowType');function checkEmptyLines(_0x2e453d,_0x1450bf,_0x43d02c){const _0x95ffa3=_0x2e453d['parent'];if(_0x95ffa3){if(_0x95ffa3['type']===nodeTypes['classBody']){const _0x2a1cb4=_0x95ffa3['body'];checkAround(_0x2e453d,_0x1450bf,_0x43d02c,[],_0x2a1cb4);}else {if(_0x95ffa3['type']===nodeTypes['program']){const _0x18b9c3=_0x95ffa3['body'];checkAround(_0x2e453d,_0x1450bf,_0x43d02c,_0x18b9c3,[]);}else {if(_0x95ffa3['type']===nodeTypes['blockStatement']){const _0x11716b=_0x95ffa3['parent'];if(_0x11716b&&_0x11716b['type']===nodeTypes['classBody']){const _0x3f964=_0x11716b['body'];checkAround(_0x2e453d,_0x1450bf,_0x43d02c,[],_0x3f964);}else {const _0x54e3b2=_0x95ffa3['body'];checkAround(_0x2e453d,_0x1450bf,_0x43d02c,_0x54e3b2,[]);}}}}}}__name(checkEmptyLines,'checkEmptyLines');const mustPutEmptyLine=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[{'checktypes':defaultChecktypes}],'create':__name((_0x352a89,_0x3b09ca)=>{const _0x27b957=_0x352a89['sourceCode'],_0x175758=_0x3b09ca[0x4*0x39f+0x1629*-0x1+0x7ad]['checktypes']??defaultChecktypes,_0x1fa77e={};for(const _0x38466c of _0x175758){if(_0x38466c===nodeTypes['methodDefinition'])_0x1fa77e[_0x38466c]=_0x1e0680=>{checkEmptyLines(_0x1e0680,_0x352a89,_0x27b957);};else {if(_0x38466c===nodeTypes['functionExpression'])_0x1fa77e[_0x38466c]=_0x2e0ee5=>{!isMethodFunction(_0x2e0ee5)&&checkEmptyLines(_0x2e0ee5,_0x352a89,_0x27b957);};else _0x38466c===nodeTypes['variableDeclaration']?_0x1fa77e[_0x38466c]=_0x362ffa=>{const _0x52eb3a=_0x362ffa['declarations'][0x1*0x1b37+-0x72e+0xdf*-0x17]?.['init'];_0x52eb3a?.['type']&&isFunctionOrArrowType(_0x52eb3a['type'])&&checkEmptyLines(_0x362ffa,_0x352a89,_0x27b957);}:_0x1fa77e[_0x38466c]=_0x16b24a=>{checkEmptyLines(_0x16b24a,_0x352a89,_0x27b957);};}}return _0x1fa77e;},'create')});
7
+ var __defProp=Object['defineProperty'],__name=(_0x33ce88,_0x41cd43)=>__defProp(_0x33ce88,'name',{'value':_0x41cd43,'configurable':!![]});const ruleName='must-put-empty-line';const constants={'meta':{'type':'layout','docs':{'description':'Enforce\x20empty\x20lines\x20above\x20and\x20below\x20control\x20structures\x20and\x20functions'},'messages':{'emptyLineRequired':'must-put-empty-line\x0aYou\x20must\x20always\x20put\x20an\x20empty\x20line\x20{{position}}\x20{{node}}\x20for\x20better\x20code\x20readability.\x0a\x0a###\x20**Must**\x20put\x20empty\x20line\x20above\x20and\x20below\x20function,\x20if,\x20switch,\x20for\x20i,\x20try\x20and\x20semantic\x20code\x20blocks.\x0a\x0a####\x20Wrong\x0a\x0aconst\x20foo\x20=\x20bar();\x0aif(condition()){\x0a\x20\x20\x20\x20foo();\x0a}\x0a\x0afunction\x20foo()\x20{\x0a\x20\x20\x20\x20…\x0a}\x0afunction\x20bar()\x20{\x0a\x20\x20\x20\x20…\x0a}\x0a\x0a####\x20Correct\x0a\x0aconst\x20foo\x20=\x20bar();\x0a\x0aif(condition()){\x0a\x20\x20\x20\x20foo();\x0a}\x0a\x0afunction\x20foo()\x20{\x0a\x20\x20\x20…\x0a}\x0a\x0afunction\x20bar()\x20{\x0a\x20\x20\x20…\x0a}\x0a\x0a####\x20Why\x0a\x0aEmpty\x20lines\x20around\x20control\x20structures\x20and\x20functions\x20make\x20the\x20code\x20easier\x20to\x20read\x20and\x20maintain.'},'schema':[{'type':'object','properties':{'checktypes':{'type':'array','items':{'type':'string'}}},'additionalProperties':![]}],'fixable':'whitespace'},'format':{'empty':'','newLine':'\x0a','doubleNewLine':'\x0a\x0a','space':'\x20','closeBrace':'}'},'regex':{'indentation':/^\s*/},'messages':{'positions':{'above':'above','below':'below'},'ids':{'emptyLineRequired':'emptyLineRequired'}},'sourceCode':{'tokenOptions':{'includeComments':!![]}},'rule':{'lineDistances':{'adjacent':0x1}}},createRule=ESLintUtils['RuleCreator'](_0x5a6aec=>''+url+_0x5a6aec),defaultChecktypes=[nodeTypes['functionDeclaration'],nodeTypes['ifStatement'],nodeTypes['switchStatement'],nodeTypes['forStatement'],nodeTypes['whileStatement'],nodeTypes['doWhileStatement'],nodeTypes['forInStatement'],nodeTypes['forOfStatement'],nodeTypes['tryStatement'],nodeTypes['arrowFunctionExpression'],nodeTypes['functionExpression'],nodeTypes['methodDefinition'],nodeTypes['classDeclaration'],nodeTypes['variableDeclaration']];function formatNodeType(_0x542e8d){return _0x542e8d['replace'](caseTransitionBoundary,'\x20')['trim']()['toLowerCase']();}__name(formatNodeType,'formatNodeType');function getNodeIndent(_0x4c8813,_0x31da53){const _0xec28fd=constants['regex']['indentation']['exec'](_0x31da53['getText'](_0x4c8813));return _0xec28fd?_0xec28fd[-0x1*0x1edb+0x43*0x7a+0xb*-0x19]:constants['format']['empty'];}__name(getNodeIndent,'getNodeIndent');function createFix(_0x2c93ab,_0x4a4dbb,_0x3d88f5,_0x33e244,_0x595927,_0x595ac5){const _0x3c5e7b=_0x33e244+constants['format']['doubleNewLine']+_0x595927+_0x595ac5['join'](constants['format']['newLine']);return _0x2c93ab['replaceTextRange']([_0x4a4dbb,_0x3d88f5],_0x3c5e7b);}__name(createFix,'createFix');function checkEmptyLineBelow(_0x432470,_0x525b4a,_0x1c4ce7){const _0x3a78ee=_0x1c4ce7['getTokenAfter'](_0x432470,constants['sourceCode']['tokenOptions']);if(!_0x3a78ee||_0x3a78ee['value']===constants['format']['closeBrace'])return;const _0x2a50da=_0x432470['loc']['end']['line'],_0x5c0e89=_0x3a78ee['loc']['start']['line'],_0x14d86b=_0x5c0e89-_0x2a50da;if(_0x14d86b===constants['rule']['lineDistances']['adjacent']){const _0x58fd54=getNodeIndent(_0x432470,_0x1c4ce7),_0x415e91=_0x1c4ce7['getText']()['slice'](_0x432470['range'][-0x2*-0xedc+0x1*-0x1e77+0xc0],_0x3a78ee['range'][0x1601*0x1+0x29c*-0x2+-0x10c9]),[_0x2beb7a=constants['format']['empty'],..._0x53624c]=_0x415e91['split'](constants['format']['newLine']);_0x525b4a['report']({'node':_0x432470,'messageId':constants['messages']['ids']['emptyLineRequired'],'data':{'position':constants['messages']['positions']['below'],'node':formatNodeType(_0x432470['type'])},'fix':__name(_0x412885=>createFix(_0x412885,_0x432470['range'][0x1057+-0x14f*-0x4+-0x1592],_0x3a78ee['range'][0x1207+0x29*0xc9+-0x3238],_0x2beb7a,_0x58fd54,_0x53624c),'fix')});}}__name(checkEmptyLineBelow,'checkEmptyLineBelow');function checkEmptyLineAbove(_0x4812f0,_0x124b7c,_0x5c4ee6,_0x30767e,_0xb9d7cb){const _0x5dbd0a=_0x4812f0['type']===nodeTypes['methodDefinition']&&_0x4812f0['parent']?.['type']===nodeTypes['classBody'];let _0x2e7637;_0x5dbd0a?_0x2e7637=_0x5c4ee6['indexOf'](_0x4812f0):_0x2e7637=_0x124b7c['findIndex'](_0xac2bf9=>_0xac2bf9===_0x4812f0);let _0x3fa500;_0x2e7637>-0x269d*-0x1+0x7c*0x4a+-0x4a75*0x1?_0x5dbd0a?_0x3fa500=_0x5c4ee6[_0x2e7637-(0x38e+-0x2b2+-0xdb)]:_0x3fa500=_0x124b7c[_0x2e7637-(0x1d3d+0x2c*0x67+-0x2ef0)]:_0x3fa500=void(0x298*-0x2+0xa*-0x91+0xada);if(!_0x3fa500)return;const _0x2994d0=_0x3fa500['loc']['end']['line'],_0x18e5f2=_0x4812f0['loc']['start']['line'],_0x690cbb=_0x18e5f2-_0x2994d0;if(_0x690cbb===constants['rule']['lineDistances']['adjacent']){let _0x20c1a4;_0x5dbd0a?_0x20c1a4=getNodeIndent(_0x4812f0['parent']?.['parent']||_0x4812f0,_0xb9d7cb):_0x20c1a4=getNodeIndent(_0x4812f0,_0xb9d7cb);const _0x7e53df=_0xb9d7cb['getText']()['slice'](_0x3fa500['range'][-0x1de3+-0x148c+0x3270],_0x4812f0['range'][0x50b+0x238d+0x6c4*-0x6]),[_0x2846cb=constants['format']['empty'],..._0x1c3b74]=_0x7e53df['split'](constants['format']['newLine']);_0x30767e['report']({'node':_0x4812f0,'messageId':constants['messages']['ids']['emptyLineRequired'],'data':{'position':constants['messages']['positions']['above'],'node':formatNodeType(_0x4812f0['type'])},'fix':__name(_0xa88b3c=>createFix(_0xa88b3c,_0x3fa500['range'][-0x2cd*0x5+0x1*0x972+0x490],_0x4812f0['range'][-0x10e3+0x18b*-0x9+-0x6*-0x521],_0x2846cb,_0x20c1a4,_0x1c3b74),'fix')});}}__name(checkEmptyLineAbove,'checkEmptyLineAbove');function checkAround(_0x3f1ef0,_0x35bf32,_0x22f4cf,_0xa01e55=[],_0x183e03=[]){checkEmptyLineAbove(_0x3f1ef0,_0xa01e55,_0x183e03,_0x35bf32,_0x22f4cf),checkEmptyLineBelow(_0x3f1ef0,_0x35bf32,_0x22f4cf);}__name(checkAround,'checkAround');function isFunctionOrArrowType(_0x1357aa){return _0x1357aa===nodeTypes['functionExpression']||_0x1357aa===nodeTypes['arrowFunctionExpression'];}__name(isFunctionOrArrowType,'isFunctionOrArrowType');function checkEmptyLines(_0x4c5cfb,_0xa09bb3,_0x85703b){const _0x12b38a=_0x4c5cfb['parent'];if(_0x12b38a){if(_0x12b38a['type']===nodeTypes['classBody']){const _0x218ded=_0x12b38a['body'];checkAround(_0x4c5cfb,_0xa09bb3,_0x85703b,[],_0x218ded);}else {if(_0x12b38a['type']===nodeTypes['program']){const _0x51e627=_0x12b38a['body'];checkAround(_0x4c5cfb,_0xa09bb3,_0x85703b,_0x51e627,[]);}else {if(_0x12b38a['type']===nodeTypes['blockStatement']){const _0x4a4ea6=_0x12b38a['parent'];if(_0x4a4ea6&&_0x4a4ea6['type']===nodeTypes['classBody']){const _0x21f702=_0x4a4ea6['body'];checkAround(_0x4c5cfb,_0xa09bb3,_0x85703b,[],_0x21f702);}else {const _0x93a4c6=_0x12b38a['body'];checkAround(_0x4c5cfb,_0xa09bb3,_0x85703b,_0x93a4c6,[]);}}}}}}__name(checkEmptyLines,'checkEmptyLines');const mustPutEmptyLine=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[{'checktypes':defaultChecktypes}],'create':__name((_0x4ea6a4,_0x35ad4b)=>{const _0x100a37=_0x4ea6a4['sourceCode'],_0x57fe19=_0x35ad4b[0x1*-0x11bd+0x22+0x119b*0x1]['checktypes']??defaultChecktypes,_0x2a7765={};for(const _0x30b8be of _0x57fe19){if(_0x30b8be===nodeTypes['methodDefinition'])_0x2a7765[_0x30b8be]=_0x2196ad=>{checkEmptyLines(_0x2196ad,_0x4ea6a4,_0x100a37);};else {if(_0x30b8be===nodeTypes['functionExpression'])_0x2a7765[_0x30b8be]=_0x4c6e51=>{!isMethodFunction(_0x4c6e51)&&checkEmptyLines(_0x4c6e51,_0x4ea6a4,_0x100a37);};else _0x30b8be===nodeTypes['variableDeclaration']?_0x2a7765[_0x30b8be]=_0xe7382f=>{const _0x15abc6=_0xe7382f['declarations'][-0x73*-0x7+0x13*0x185+0x2*-0x1002]?.['init'];_0x15abc6?.['type']&&isFunctionOrArrowType(_0x15abc6['type'])&&checkEmptyLines(_0xe7382f,_0x4ea6a4,_0x100a37);}:_0x2a7765[_0x30b8be]=_0x5e7014=>{checkEmptyLines(_0x5e7014,_0x4ea6a4,_0x100a37);};}}return _0x2a7765;},'create')});
7
8
 
8
- export { mustPutEmptyLine as default };
9
+ export { mustPutEmptyLine as default, ruleName };
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { nodeTypes, isMemberExpression, isIdentifier, isNameMatch, isStringLiteral } from '@flint/infra/ast-helpers';
3
+ import { nodeTypes, isMemberExpression, isIdentifier, isNameMatch, isStringLiteral } from '@flint/infra/analysis';
4
4
  import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
5
5
 
6
- var __defProp=Object['defineProperty'],__name=(_0x51be57,_0x41bdbd)=>__defProp(_0x51be57,'name',{'value':_0x41bdbd,'configurable':!![]});const ruleName='must-throw-full-error-objects';const ruleId='mustThrowFullErrorObjects';const constants={'meta':{'type':ruleTypes['problem'],'docs':{'description':ruleName},'messages':{[ruleId]:ruleName+'\x0a###\x20**Must**\x20throw\x20full\x20error\x20objects.\x0a\x0a####\x20Wrong\x0a\x0atry\x20{\x0a\x20\x20...\x0a}\x20catch\x20(error)\x20{\x0a\x20\x20throw\x20error\x20instanceof\x20Error\x20?\x20error.message\x20:\x20toolboxErrorMessages.unknown;\x0a}\x0a\x0a####\x20Correct\x0a\x0atry\x20{\x0a\x20\x20...\x0a}\x20catch\x20(error)\x20{\x0a\x20\x20...\x0a\x20\x20throw\x20error;\x0a}\x0a\x0a####\x20Why\x0aThrowing\x20`error.message`\x20loses\x20stack\x20traces\x20and\x20context,\x20making\x20debugging\x20harder.'},'schema':[]}},propertyNames={'message':'message'},createRule=ESLintUtils['RuleCreator'](_0x20d194=>''+url+_0x20d194),mustThrowFullErrorObjects=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x38474f){return {[nodeTypes['throwStatement']](_0x574faa){const _0xfa4df5=_0x574faa['argument'];if(!_0xfa4df5)return;let _0x526264=shouldReportThrownExpression(_0xfa4df5);_0x526264&&_0x38474f['report']({'node':_0x574faa,'messageId':ruleId});}};}});function isMessageMemberExpression(_0x37c0ff){return !!_0x37c0ff&&isMemberExpression(_0x37c0ff)&&isIdentifier(_0x37c0ff['property'])&&isNameMatch(_0x37c0ff['property'],propertyNames['message']);}__name(isMessageMemberExpression,'isMessageMemberExpression');function isDisallowedOperand(_0x3ecf6a){return isMessageMemberExpression(_0x3ecf6a)||isStringLiteral(_0x3ecf6a);}__name(isDisallowedOperand,'isDisallowedOperand');function shouldReportThrownExpression(_0x920c13){return isDisallowedOperand(_0x920c13)||_0x920c13['type']===nodeTypes['conditionalExpression']&&(isDisallowedOperand(_0x920c13['consequent'])||isDisallowedOperand(_0x920c13['alternate']))||_0x920c13['type']===nodeTypes['logicalExpression']&&(isDisallowedOperand(_0x920c13['left'])||isDisallowedOperand(_0x920c13['right']));}__name(shouldReportThrownExpression,'shouldReportThrownExpression');
6
+ var __defProp=Object['defineProperty'],__name=(_0x307474,_0x2a02d6)=>__defProp(_0x307474,'name',{'value':_0x2a02d6,'configurable':!![]});const ruleName='must-throw-full-error-objects';const ruleId='mustThrowFullErrorObjects';const constants={'meta':{'type':ruleTypes['problem'],'docs':{'description':ruleName},'messages':{[ruleId]:ruleName+'\x0a###\x20**Must**\x20throw\x20full\x20error\x20objects.\x0a\x0a####\x20Wrong\x0a\x0atry\x20{\x0a\x20\x20...\x0a}\x20catch\x20(error)\x20{\x0a\x20\x20throw\x20error\x20instanceof\x20Error\x20?\x20error.message\x20:\x20toolboxErrorMessages.unknown;\x0a}\x0a\x0a####\x20Correct\x0a\x0atry\x20{\x0a\x20\x20...\x0a}\x20catch\x20(error)\x20{\x0a\x20\x20...\x0a\x20\x20throw\x20error;\x0a}\x0a\x0a####\x20Why\x0aThrowing\x20`error.message`\x20loses\x20stack\x20traces\x20and\x20context,\x20making\x20debugging\x20harder.'},'schema':[]}},propertyNames={'message':'message'},createRule=ESLintUtils['RuleCreator'](_0x3a8c94=>''+url+_0x3a8c94),mustThrowFullErrorObjects=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x17ceab){return {[nodeTypes['throwStatement']](_0x776f58){const _0x192f41=_0x776f58['argument'];if(!_0x192f41)return;let _0x598876=shouldReportThrownExpression(_0x192f41);_0x598876&&_0x17ceab['report']({'node':_0x776f58,'messageId':ruleId});}};}});function isMessageMemberExpression(_0x3428a1){return !!_0x3428a1&&isMemberExpression(_0x3428a1)&&isIdentifier(_0x3428a1['property'])&&isNameMatch(_0x3428a1['property'],propertyNames['message']);}__name(isMessageMemberExpression,'isMessageMemberExpression');function isDisallowedOperand(_0x19dd9c){return isMessageMemberExpression(_0x19dd9c)||isStringLiteral(_0x19dd9c);}__name(isDisallowedOperand,'isDisallowedOperand');function shouldReportThrownExpression(_0x399fe2){return isDisallowedOperand(_0x399fe2)||_0x399fe2['type']===nodeTypes['conditionalExpression']&&(isDisallowedOperand(_0x399fe2['consequent'])||isDisallowedOperand(_0x399fe2['alternate']))||_0x399fe2['type']===nodeTypes['logicalExpression']&&(isDisallowedOperand(_0x399fe2['left'])||isDisallowedOperand(_0x399fe2['right']));}__name(shouldReportThrownExpression,'shouldReportThrownExpression');
7
7
 
8
8
  export { mustThrowFullErrorObjects as default, ruleId, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-use-camelcase-for-html-items-id-attribute";
2
3
  declare const mustUseCamelcaseForHtmlItemsIdAttribute: ESLintUtils.RuleModule<"mustUseCamelcaseForHtmlItemsIdAttribute", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustUseCamelcaseForHtmlItemsIdAttribute;
@@ -1,9 +1,9 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { isStringLiteral, nodeTypes } from '@flint/infra/ast-helpers';
3
+ import { isStringLiteral, nodeTypes, isCamelCase } from '@flint/infra/analysis';
4
4
  import { startsWithUpperCasePattern } from '@flint/infra/constants/rules-regex';
5
- import { isCamelCase } from '@flint/infra/ast-helpers/name-analysis';
5
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
6
6
 
7
- const constants={'url':'https://example.com/rules/','ruleName':'must-use-camelcase-for-html-items-id-attribute','messageIds':{'mustUseCamelcaseForHtmlItemsIdAttribute':'mustUseCamelcaseForHtmlItemsIdAttribute'},'meta':{'type':'problem','docs':{'description':'Must\x20use\x20camelCase\x20in\x20html\x20items\x20id\x20attributes','recommended':!![]},'messages':{'mustUseCamelcaseForHtmlItemsIdAttribute':'must-use-camelcase-for-html-items-id-attribute\x0a###\x20**Must**\x20use\x20camelCase\x20in\x20html\x20element\x20id\x20attribute.\x0a\x0a####\x20Wrong:\x0a\x0a<div\x20id\x20=\x20\x22snake_case\x22>\x0a\x0a####\x20Correct:\x0a\x0a<div\x20id\x20=\x20\x22camelCase\x22>\x0a\x0a####\x20Why:\x0a\x0aIn\x20code\x20rules\x20we\x20name\x20consts\x20in\x20the\x20camelCase\x20'},'schema':[]},'attrName':'id','templateJoiner':'${}','invalidSymbols':/[_-]/,'emptyString':''},createRule=ESLintUtils['RuleCreator'](_0xce9cf2=>''+constants['url']+_0xce9cf2),mustUseCamelcaseForHtmlItemsIdAttribute=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x3145fa){return {'JSXAttribute'(_0x2027ef){const _0x2162f9=_0x2027ef['value'];if(_0x2027ef['name']['name']!==constants['attrName']||!_0x2162f9)return;let _0x395235,_0x509c47=![];if(isStringLiteral(_0x2162f9))_0x395235=_0x2162f9['value'];else {if(_0x2162f9['type']===nodeTypes['JSXExpressionContainer']){const _0x4728ef=_0x2162f9['expression'];if(isStringLiteral(_0x4728ef))_0x395235=_0x4728ef['value'];else {if(_0x4728ef['type']===nodeTypes['templateLiteral']){const _0x25c523=_0x4728ef['quasis']['map'](_0xbed757=>_0xbed757['value']['cooked']??constants['emptyString'])['join'](constants['templateJoiner']);if(_0x4728ef['expressions']['length']===-0xb*-0x286+-0x1*-0x1c25+-0x37e7)_0x395235=_0x25c523;else (constants['invalidSymbols']['test'](_0x25c523)||startsWithUpperCasePattern['test'](_0x25c523))&&(_0x509c47=!![]);}else _0x4728ef['type']===nodeTypes['identifier']&&!isCamelCase(_0x4728ef['name'])&&(_0x509c47=!![]);}}}(_0x509c47||_0x395235!==void(-0x237d+-0xec4+-0x53*-0x9b)&&!isCamelCase(_0x395235))&&_0x3145fa['report']({'node':_0x2027ef,'messageId':constants['messageIds']['mustUseCamelcaseForHtmlItemsIdAttribute']});}};}});
7
+ const ruleName='must-use-camelcase-for-html-items-id-attribute';const constants={'messageIds':{'mustUseCamelcaseForHtmlItemsIdAttribute':'mustUseCamelcaseForHtmlItemsIdAttribute'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Must\x20use\x20camelCase\x20in\x20html\x20items\x20id\x20attributes','recommended':!![]},'messages':{'mustUseCamelcaseForHtmlItemsIdAttribute':'must-use-camelcase-for-html-items-id-attribute\x0a###\x20**Must**\x20use\x20camelCase\x20in\x20html\x20element\x20id\x20attribute.\x0a\x0a####\x20Wrong:\x0a\x0a<div\x20id\x20=\x20\x22snake_case\x22>\x0a\x0a####\x20Correct:\x0a\x0a<div\x20id\x20=\x20\x22camelCase\x22>\x0a\x0a####\x20Why:\x0a\x0aIn\x20code\x20rules\x20we\x20name\x20consts\x20in\x20the\x20camelCase\x20'},'schema':[]},'attrName':'id','templateJoiner':'${}','invalidSymbols':/[_-]/,'emptyString':''},createRule=ESLintUtils['RuleCreator'](_0x371bbc=>''+url+_0x371bbc),mustUseCamelcaseForHtmlItemsIdAttribute=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x4a180a){return {'JSXAttribute'(_0x558bae){const _0x1c5427=_0x558bae['value'];if(_0x558bae['name']['name']!==constants['attrName']||!_0x1c5427)return;let _0x4a00ae,_0x58c476=![];if(isStringLiteral(_0x1c5427))_0x4a00ae=_0x1c5427['value'];else {if(_0x1c5427['type']===nodeTypes['JSXExpressionContainer']){const _0x346dba=_0x1c5427['expression'];if(isStringLiteral(_0x346dba))_0x4a00ae=_0x346dba['value'];else {if(_0x346dba['type']===nodeTypes['templateLiteral']){const _0x62a047=_0x346dba['quasis']['map'](_0x253bad=>_0x253bad['value']['cooked']??constants['emptyString'])['join'](constants['templateJoiner']);if(_0x346dba['expressions']['length']===0x106f+0x3fb+-0x86*0x27)_0x4a00ae=_0x62a047;else (constants['invalidSymbols']['test'](_0x62a047)||startsWithUpperCasePattern['test'](_0x62a047))&&(_0x58c476=!![]);}else _0x346dba['type']===nodeTypes['identifier']&&!isCamelCase(_0x346dba['name'])&&(_0x58c476=!![]);}}}(_0x58c476||_0x4a00ae!==void(0x44*0x1f+0x1f*0x95+0xd9*-0x1f)&&!isCamelCase(_0x4a00ae))&&_0x4a180a['report']({'node':_0x558bae,'messageId':constants['messageIds']['mustUseCamelcaseForHtmlItemsIdAttribute']});}};}});
8
8
 
9
- export { mustUseCamelcaseForHtmlItemsIdAttribute as default };
9
+ export { mustUseCamelcaseForHtmlItemsIdAttribute as default, ruleName };
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
- import { getFunctionName, nodeTypes, isPropertyNamed, normalizeNodes } from '@flint/infra/ast-helpers';
3
- import { createEslintRule } from '@flint/infra/utils/create-eslint-rule';
2
+ import { getFunctionName, nodeTypes, isPropertyNamed, normalizeNodes } from '@flint/infra/analysis';
3
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
4
4
 
5
- var __defProp=Object['defineProperty'],__name=(_0x5b5be0,_0x5da6a4)=>__defProp(_0x5b5be0,'name',{'value':_0x5da6a4,'configurable':!![]});const ruleName='must-use-descriptive-names-for-functions-and-parameters';const ruleContent='\x0a###\x20**Must**\x20use\x20descriptive\x20names\x20for\x20functions\x20and\x20parameters.\x0a\x0a####\x20Wrong\x0a\x0afunction\x20calc(a,\x20b)\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0a####\x20Correct\x0a\x0afunction\x20calculateTotalPrice(item,\x20amount)\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0a####\x20Why\x0a\x0aThis\x20makes\x20your\x20code\x20clearer\x20and\x20improves\x20readability.',allowedFunctionNames=new Set(['add','run','url','map','get','top','log']),allowedParameterNames=new Set(['_','mr','id']);var mustUseDescriptiveNamesForFunctionsAndParameters = createEslintRule(ruleName,ruleContent,__name(function create(_0x5509c5,_0x5cf338){const _0x44fb7e=_0x5cf338[0x6f*0x3d+0x529*0x5+-0x3440]?.['minFunctionNameLength']??0x29*-0xde+0x242a+-0x98,_0x3d294a=_0x5cf338[-0x1ec2+-0x122+0x13a*0x1a]?.['minParameterNameLength']??0x1ef0+0x6f*0x56+-0x16bd*0x3;return {'FunctionDeclaration,\x20FunctionExpression'(_0x2fdbdc){const _0x3a1c44=getFunctionName(_0x2fdbdc);if(_0x2fdbdc['parent']['type']===nodeTypes['property']&&isPropertyNamed(_0x2fdbdc['parent'],'fix'))return;_0x3a1c44&&!allowedFunctionNames['has'](_0x3a1c44)&&_0x3a1c44['length']<_0x44fb7e&&_0x5509c5['report']({'node':_0x2fdbdc,'messageId':ruleName});if(!_0x2fdbdc['params']['length'])return;for(const _0x4d0bed of _0x2fdbdc['params']){const _0x42c98a=getParameterIdentifiers(_0x4d0bed);for(const _0x3c973a of _0x42c98a){!allowedParameterNames['has'](_0x3c973a['name'])&&_0x3c973a['name']['length']<_0x3d294a&&_0x5509c5['report']({'node':_0x3c973a,'messageId':ruleName});}}}};},'create'),{'schema':[{'type':'object','properties':{'minFunctionNameLength':{'type':'integer'},'minParameterNameLength':{'type':'integer'}},'additionalProperties':![]}],'defaultOptions':[{'minFunctionNameLength':0x4,'minParameterNameLength':0x3}]});function getParameterIdentifiers(_0x7474b){switch(_0x7474b['type']){case 'Identifier':return [_0x7474b];case 'ObjectPattern':return getIdentifiersFromObjectProperties(_0x7474b['properties']);case 'ArrayPattern':return getIdentifiersFromArrayElements(normalizeNodes(_0x7474b['elements']));case 'RestElement':return getParameterIdentifiers(_0x7474b['argument']);case 'AssignmentPattern':return getParameterIdentifiers(_0x7474b['left']);default:return [];}}__name(getParameterIdentifiers,'getParameterIdentifiers');function getIdentifiersFromObjectProperties(_0x5b6d20){const _0x12a833=[];for(const _0xae0db4 of _0x5b6d20){if(_0xae0db4['type']===nodeTypes['property'])_0x12a833['push'](...getParameterIdentifiers(_0xae0db4['value']));else _0xae0db4['type']===nodeTypes['restElement']&&_0x12a833['push'](...getParameterIdentifiers(_0xae0db4['argument']));}return _0x12a833;}__name(getIdentifiersFromObjectProperties,'getIdentifiersFromObjectProperties');function getIdentifiersFromArrayElements(_0x535083){const _0x5ee174=[];for(const _0x36bc42 of _0x535083){_0x36bc42&&_0x5ee174['push'](...getParameterIdentifiers(_0x36bc42));}return _0x5ee174;}__name(getIdentifiersFromArrayElements,'getIdentifiersFromArrayElements');
5
+ var __defProp=Object['defineProperty'],__name=(_0x3c29f2,_0x21f9ac)=>__defProp(_0x3c29f2,'name',{'value':_0x21f9ac,'configurable':!![]});const ruleName='must-use-descriptive-names-for-functions-and-parameters';const ruleContent='\x0a###\x20**Must**\x20use\x20descriptive\x20names\x20for\x20functions\x20and\x20parameters.\x0a\x0a####\x20Wrong\x0a\x0afunction\x20calc(a,\x20b)\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0a####\x20Correct\x0a\x0afunction\x20calculateTotalPrice(item,\x20amount)\x20{\x0a\x20\x20\x20\x20...\x0a}\x0a\x0a####\x20Why\x0a\x0aThis\x20makes\x20your\x20code\x20clearer\x20and\x20improves\x20readability.',allowedFunctionNames=new Set(['add','run','url','map','get','top','log']),allowedParameterNames=new Set(['_','mr','id']);var mustUseDescriptiveNamesForFunctionsAndParameters = createEslintRule(ruleName,ruleContent,__name(function create(_0x2fcf83,_0x3efa13){const _0x3eaa51=_0x3efa13[-0x3d*-0x49+0x1b40+0x40f*-0xb]?.['minFunctionNameLength']??0x152b+0x6df+-0x2*0xe03,_0x372f68=_0x3efa13[0x1a08+-0x1*-0x1887+0x328f*-0x1]?.['minParameterNameLength']??-0x1edc+0xbcd+0x1312;return {'FunctionDeclaration,\x20FunctionExpression'(_0xc0a960){const _0x4fd813=getFunctionName(_0xc0a960);if(_0xc0a960['parent']['type']===nodeTypes['property']&&isPropertyNamed(_0xc0a960['parent'],'fix'))return;_0x4fd813&&!allowedFunctionNames['has'](_0x4fd813)&&_0x4fd813['length']<_0x3eaa51&&_0x2fcf83['report']({'node':_0xc0a960,'messageId':ruleName});if(!_0xc0a960['params']['length'])return;for(const _0x5d8337 of _0xc0a960['params']){const _0x113103=getParameterIdentifiers(_0x5d8337);for(const _0x68e94 of _0x113103){!allowedParameterNames['has'](_0x68e94['name'])&&_0x68e94['name']['length']<_0x372f68&&_0x2fcf83['report']({'node':_0x68e94,'messageId':ruleName});}}}};},'create'),{'schema':[{'type':'object','properties':{'minFunctionNameLength':{'type':'integer'},'minParameterNameLength':{'type':'integer'}},'additionalProperties':![]}],'defaultOptions':[{'minFunctionNameLength':0x4,'minParameterNameLength':0x3}]});function getParameterIdentifiers(_0x4d441d){switch(_0x4d441d['type']){case 'Identifier':return [_0x4d441d];case 'ObjectPattern':return getIdentifiersFromObjectProperties(_0x4d441d['properties']);case 'ArrayPattern':return getIdentifiersFromArrayElements(normalizeNodes(_0x4d441d['elements']));case 'RestElement':return getParameterIdentifiers(_0x4d441d['argument']);case 'AssignmentPattern':return getParameterIdentifiers(_0x4d441d['left']);default:return [];}}__name(getParameterIdentifiers,'getParameterIdentifiers');function getIdentifiersFromObjectProperties(_0x46c592){const _0x1728b8=[];for(const _0x26ffa1 of _0x46c592){if(_0x26ffa1['type']===nodeTypes['property'])_0x1728b8['push'](...getParameterIdentifiers(_0x26ffa1['value']));else _0x26ffa1['type']===nodeTypes['restElement']&&_0x1728b8['push'](...getParameterIdentifiers(_0x26ffa1['argument']));}return _0x1728b8;}__name(getIdentifiersFromObjectProperties,'getIdentifiersFromObjectProperties');function getIdentifiersFromArrayElements(_0x4ebc7a){const _0x3979cc=[];for(const _0x41af5b of _0x4ebc7a){_0x41af5b&&_0x3979cc['push'](...getParameterIdentifiers(_0x41af5b));}return _0x3979cc;}__name(getIdentifiersFromArrayElements,'getIdentifiersFromArrayElements');
6
6
 
7
7
  export { mustUseDescriptiveNamesForFunctionsAndParameters as default, ruleName };
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
- import { createEslintRule } from '@flint/infra/utils/create-eslint-rule';
3
- import { isIdentifier, isNameMatch, isMemberExpression, isStaticLiteral } from '@flint/infra/ast-helpers';
2
+ import { createEslintRule } from '@flint/infra/create-eslint-rule';
3
+ import { isIdentifier, isNameMatch, isMemberExpression, isStaticLiteral } from '@flint/infra/analysis';
4
4
 
5
- var __defProp=Object['defineProperty'],__name=(_0x1ba8cb,_0x4e7aa5)=>__defProp(_0x1ba8cb,'name',{'value':_0x4e7aa5,'configurable':!![]});const ruleName='must-use-env-keys-from-constant';const ruleContent='\x0a###\x20**Must**\x20use\x20env\x20keys\x20from\x20constant.\x0a\x0a####\x20Wrong\x0a\x0aconst\x20ciProjectId\x20=\x20process.env.CI_PROJECT_ID;\x0a\x0aconst\x20dev\x20=\x20getStringEnvSetting(\x22CI_PROJECT_ID\x22);\x0a\x0a####\x20Correct\x0a\x0aconst\x20projectId\x20=\x20process.env[environmentVariables.ciProjectId];\x0a\x0aconst\x20ciProjectId\x20=\x20getStringEnvSetting(environmentVariables.ciProjectId);\x0a\x0a####\x20Why\x0a\x0aEnvironment\x20variable\x20keys\x20must\x20be\x20taken\x20from\x20a\x20constant\x20instead\x20of\x20being\x20written\x20directly.\x20This\x20keeps\x20all\x20environment\x20variable\x20names\x20centralized,\x20prevents\x20duplication\x20and\x20typos,\x20and\x20makes\x20refactoring\x20safer.\x0a';var mustUseEnvKeysFromConstant = createEslintRule(ruleName,ruleContent,__name(function create(_0x2f61d1){return {'CallExpression'(_0x4461dd){const _0x5a05ba=_0x4461dd['arguments'],_0x436c8f=isIdentifier(_0x4461dd['callee'])&&constants['getterNameRegex']['test'](_0x4461dd['callee']['name']);_0x436c8f&&isStaticLiteral(_0x5a05ba[-0xdc3+-0x4b8+0x127b])&&_0x2f61d1['report']({'node':_0x5a05ba[0x19f1*0x1+0xba3+0x4*-0x965],'messageId':ruleName});},'MemberExpression'(_0x43d68c){const _0x4fcd40=_0x43d68c['parent'],_0x1c299b=isIdentifier(_0x43d68c['object'])&&isNameMatch(_0x43d68c['object'],'process')&&isIdentifier(_0x43d68c['property'])&&isNameMatch(_0x43d68c['property'],'env');if(!_0x1c299b||!isMemberExpression(_0x4fcd40))return;const _0x564b6f=!_0x4fcd40['computed']||isStaticLiteral(_0x4fcd40['property']);_0x564b6f&&_0x2f61d1['report']({'node':_0x4fcd40['property'],'messageId':ruleName});}};},'create'));const constants={'getterNameRegex':/^get(String|RequiredString|Number|Boolean)EnvSetting$/};
5
+ var __defProp=Object['defineProperty'],__name=(_0x5ad98c,_0x540db7)=>__defProp(_0x5ad98c,'name',{'value':_0x540db7,'configurable':!![]});const ruleName='must-use-env-keys-from-constant';const ruleContent='\x0a###\x20**Must**\x20use\x20env\x20keys\x20from\x20constant.\x0a\x0a####\x20Wrong\x0a\x0aconst\x20ciProjectId\x20=\x20process.env.CI_PROJECT_ID;\x0a\x0aconst\x20dev\x20=\x20getStringEnvSetting(\x22CI_PROJECT_ID\x22);\x0a\x0a####\x20Correct\x0a\x0aconst\x20projectId\x20=\x20process.env[environmentVariables.ciProjectId];\x0a\x0aconst\x20ciProjectId\x20=\x20getStringEnvSetting(environmentVariables.ciProjectId);\x0a\x0a####\x20Why\x0a\x0aEnvironment\x20variable\x20keys\x20must\x20be\x20taken\x20from\x20a\x20constant\x20instead\x20of\x20being\x20written\x20directly.\x20This\x20keeps\x20all\x20environment\x20variable\x20names\x20centralized,\x20prevents\x20duplication\x20and\x20typos,\x20and\x20makes\x20refactoring\x20safer.\x0a';var mustUseEnvKeysFromConstant = createEslintRule(ruleName,ruleContent,__name(function create(_0x520508){return {'CallExpression'(_0x4babd0){const _0xf942f6=_0x4babd0['arguments'],_0x692e41=isIdentifier(_0x4babd0['callee'])&&constants['getterNameRegex']['test'](_0x4babd0['callee']['name']);_0x692e41&&isStaticLiteral(_0xf942f6[-0x275*-0x5+-0x7f3*-0x1+-0x143c])&&_0x520508['report']({'node':_0xf942f6[-0x1348+-0x19*-0x13+0x116d*0x1],'messageId':ruleName});},'MemberExpression'(_0x1e0f41){const _0x1e36e9=_0x1e0f41['parent'],_0x2c02aa=isIdentifier(_0x1e0f41['object'])&&isNameMatch(_0x1e0f41['object'],'process')&&isIdentifier(_0x1e0f41['property'])&&isNameMatch(_0x1e0f41['property'],'env');if(!_0x2c02aa||!isMemberExpression(_0x1e36e9))return;const _0x44588f=!_0x1e36e9['computed']||isStaticLiteral(_0x1e36e9['property']);_0x44588f&&_0x520508['report']({'node':_0x1e36e9['property'],'messageId':ruleName});}};},'create'));const constants={'getterNameRegex':/^get(String|RequiredString|Number|Boolean)EnvSetting$/};
6
6
 
7
7
  export { mustUseEnvKeysFromConstant as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-use-example-domain";
2
3
  declare const mustUseExampleDomain: ESLintUtils.RuleModule<"invalidEmailDomain", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustUseExampleDomain;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { isTestFile } from '@flint/infra/ast-helpers';
3
+ import { isTestFile } from '@flint/infra/analysis';
4
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0x56fa50,_0x11b0e9)=>__defProp(_0x56fa50,'name',{'value':_0x11b0e9,'configurable':!![]});const constants={'url':'https://example.com/rules/','ruleName':'must-use-example-domain','messageIds':{'invalidEmailDomain':'invalidEmailDomain'},'meta':{'type':'problem','docs':{'description':'Test\x20email\x20addresses\x20must\x20use\x20@example.com\x20domain'},'messages':{'invalidEmailDomain':'must-use-example-domain\x0aEmail\x20address\x20must\x20use\x20@example.com\x20domain:\x20\x27{{\x20email\x20}}\x27\x20is\x20not\x20allowed.\x0a\x0a###\x20**Must**\x20write\x20test\x20emails\x20with\x20example.com\x20domain.\x0a\x0a####\x20Wrong:\x0a\x0afoo@test.com\x0a\x0a####\x20Correct:\x0a\x0afoo@example.com\x0a\x0a####\x20Why:\x0a\x0aExample.com\x20is\x20a\x20special\x20domain\x20for\x20testing.\x20Someone\x20owns\x20test.com\x20domain.'},'schema':[]},'email':{'requiredDomain':'@example.com','atSymbol':'@'},'regex':{'allAtSymbols':/@/g},'types':{'string':'string'},'nodeKeys':{'value':'value'},'emailPattern':/\b[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}\b/},createRule=ESLintUtils['RuleCreator'](_0x1df175=>''+constants['url']+_0x1df175);function reportInvalidEmails(_0x27f3b2,_0x39559a,_0x1f1797){const _0x3e1dcc=_0x27f3b2['split'](constants['regex']['allAtSymbols'])['length']-(-0x2258+-0xcf*0x17+0x34f2),_0x35c192=constants['emailPattern']['test'](_0x27f3b2['trim']()),_0x340cc4=_0x35c192&&_0x3e1dcc===0x13b6+0x7f7+-0x1bac&&!_0x27f3b2['startsWith'](constants['email']['atSymbol'])&&!_0x27f3b2['endsWith'](constants['email']['requiredDomain']);_0x340cc4&&_0x1f1797['report']({'node':_0x39559a,'messageId':constants['messageIds']['invalidEmailDomain'],'data':{'email':_0x27f3b2}});}__name(reportInvalidEmails,'reportInvalidEmails');const mustUseExampleDomain=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x2cf9a6){const _0x11dd41=_0x2cf9a6['filename'];let _0x49eaa1={};return isTestFile(_0x11dd41)&&(_0x49eaa1={'Literal'(_0x2051b8){const _0x2e2c25=_0x2051b8[constants['nodeKeys']['value']];typeof _0x2e2c25==='string'&&reportInvalidEmails(_0x2e2c25,_0x2051b8,_0x2cf9a6);}}),_0x49eaa1;}});
6
+ var __defProp=Object['defineProperty'],__name=(_0x52f2b4,_0x95a29d)=>__defProp(_0x52f2b4,'name',{'value':_0x95a29d,'configurable':!![]});const ruleName='must-use-example-domain';const constants={'messageIds':{'invalidEmailDomain':'invalidEmailDomain'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Test\x20email\x20addresses\x20must\x20use\x20@example.com\x20domain'},'messages':{'invalidEmailDomain':'must-use-example-domain\x0aEmail\x20address\x20must\x20use\x20@example.com\x20domain:\x20\x27{{\x20email\x20}}\x27\x20is\x20not\x20allowed.\x0a\x0a###\x20**Must**\x20write\x20test\x20emails\x20with\x20example.com\x20domain.\x0a\x0a####\x20Wrong:\x0a\x0afoo@test.com\x0a\x0a####\x20Correct:\x0a\x0afoo@example.com\x0a\x0a####\x20Why:\x0a\x0aExample.com\x20is\x20a\x20special\x20domain\x20for\x20testing.\x20Someone\x20owns\x20test.com\x20domain.'},'schema':[]},'email':{'requiredDomain':'@example.com','atSymbol':'@'},'regex':{'allAtSymbols':/@/g},'types':{'string':'string'},'nodeKeys':{'value':'value'},'emailPattern':/\b[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}\b/},createRule=ESLintUtils['RuleCreator'](_0x31b478=>''+url+_0x31b478);function reportInvalidEmails(_0x4845f6,_0xa0ae51,_0x18807a){const _0x656ece=_0x4845f6['split'](constants['regex']['allAtSymbols'])['length']-(0x1*0x255f+-0x169f+-0x97*0x19),_0x25b4b8=constants['emailPattern']['test'](_0x4845f6['trim']()),_0x889f77=_0x25b4b8&&_0x656ece===0x2515*0x1+-0xc4f+-0x18c5&&!_0x4845f6['startsWith'](constants['email']['atSymbol'])&&!_0x4845f6['endsWith'](constants['email']['requiredDomain']);_0x889f77&&_0x18807a['report']({'node':_0xa0ae51,'messageId':constants['messageIds']['invalidEmailDomain'],'data':{'email':_0x4845f6}});}__name(reportInvalidEmails,'reportInvalidEmails');const mustUseExampleDomain=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x42545a){const _0x1684e8=_0x42545a['filename'];let _0x12382e={};return isTestFile(_0x1684e8)&&(_0x12382e={'Literal'(_0x3e7711){const _0x544b28=_0x3e7711[constants['nodeKeys']['value']];typeof _0x544b28==='string'&&reportInvalidEmails(_0x544b28,_0x3e7711,_0x42545a);}}),_0x12382e;}});
6
7
 
7
- export { mustUseExampleDomain as default };
8
+ export { mustUseExampleDomain as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-use-filename-in-assert-functions";
2
3
  declare const mustUseFilenameInAssertFunctions: ESLintUtils.RuleModule<"mustUseFilenameInAssertFunctions", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustUseFilenameInAssertFunctions;
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
  import { ESLintUtils } from '@typescript-eslint/utils';
3
- import { getFileName, nodeTypes } from '@flint/infra/ast-helpers';
3
+ import { getFileName, nodeTypes } from '@flint/infra/analysis';
4
+ import { ruleTypes, url } from '@flint/infra/constants/rules-meta';
4
5
 
5
- var __defProp=Object['defineProperty'],__name=(_0x16b549,_0x1e6d5c)=>__defProp(_0x16b549,'name',{'value':_0x1e6d5c,'configurable':!![]});const constants={'url':'https://example.com/rules/','ruleName':'must-use-filename-in-assert-functions','messageIds':{'mustUseFilenameInAssertFunctions':'mustUseFilenameInAssertFunctions'},'meta':{'type':'problem','docs':{'description':'Assert\x20functions\x20must\x20use\x20filename\x20in\x20their\x20name.','recommended':'error'},'messages':{'mustUseFilenameInAssertFunctions':'must-use-filename-in-assert-functions\x0a###\x20**Must**\x20use\x20filename\x20in\x20assert\x20functions.\x0a\x0a####\x20Wrong:\x0a\x0a//table-asserts.ts\x0aexport\x20function\x20assertGetFoo()\x20{...}\x0a\x0a####\x20Correct:\x0a\x0a//table-asserts.ts\x0aexport\x20function\x20assertTableGetFoo()\x20{...}\x0a\x0a####\x20Why:\x0a\x0aThis\x20improves\x20clarity\x20and\x20helps\x20with\x20naming\x20conflicts.'},'schema':[]},'assertFunctionSubString':'assert','assertStringsToRemove':['-asserts','-asserter','-']},createRule=ESLintUtils['RuleCreator'](_0x51b293=>''+constants['url']+_0x51b293);function validateAssertFunctionName(_0x1748b7,_0x1ee225){const _0x3fc745=_0x1748b7['name'],_0x4f4f86=getFileName(_0x1ee225['filename'],'.ts'),_0x20c9eb=constants['assertStringsToRemove']['reduce']((_0x30aafb,_0x1d64e1)=>_0x30aafb['replace'](_0x1d64e1,''),_0x4f4f86);!_0x3fc745['toLowerCase']()['includes'](_0x20c9eb)&&_0x1ee225['report']({'node':_0x1748b7,'messageId':constants['messageIds']['mustUseFilenameInAssertFunctions'],'data':{'fileName':_0x4f4f86}});}__name(validateAssertFunctionName,'validateAssertFunctionName');const mustUseFilenameInAssertFunctions=createRule({'name':constants['ruleName'],'meta':constants['meta'],'defaultOptions':[],'create'(_0x363163){return {'FunctionDeclaration'(_0x33e3ed){_0x33e3ed['id']?.['name']['toLowerCase']()['includes'](constants['assertFunctionSubString'])&&validateAssertFunctionName(_0x33e3ed['id'],_0x363163);},'VariableDeclarator'(_0x587778){_0x587778['id']['type']===nodeTypes['identifier']&&_0x587778['init']&&(_0x587778['init']['type']===nodeTypes['arrowFunctionExpression']||_0x587778['init']['type']===nodeTypes['functionExpression'])&&(_0x587778['id']['name']['toLowerCase']()['includes'](constants['assertFunctionSubString'])&&validateAssertFunctionName(_0x587778['id'],_0x363163));}};}});
6
+ var __defProp=Object['defineProperty'],__name=(_0x4686c6,_0x1a0012)=>__defProp(_0x4686c6,'name',{'value':_0x1a0012,'configurable':!![]});const ruleName='must-use-filename-in-assert-functions';const constants={'messageIds':{'mustUseFilenameInAssertFunctions':'mustUseFilenameInAssertFunctions'},'meta':{'type':ruleTypes['problem'],'docs':{'description':'Assert\x20functions\x20must\x20use\x20filename\x20in\x20their\x20name.','recommended':'error'},'messages':{'mustUseFilenameInAssertFunctions':'must-use-filename-in-assert-functions\x0a###\x20**Must**\x20use\x20filename\x20in\x20assert\x20functions.\x0a\x0a####\x20Wrong:\x0a\x0a//table-asserts.ts\x0aexport\x20function\x20assertGetFoo()\x20{...}\x0a\x0a####\x20Correct:\x0a\x0a//table-asserts.ts\x0aexport\x20function\x20assertTableGetFoo()\x20{...}\x0a\x0a####\x20Why:\x0a\x0aThis\x20improves\x20clarity\x20and\x20helps\x20with\x20naming\x20conflicts.'},'schema':[]},'assertFunctionSubString':'assert','assertStringsToRemove':['-asserts','-asserter','-']},createRule=ESLintUtils['RuleCreator'](_0x57bfa1=>''+url+_0x57bfa1);function validateAssertFunctionName(_0x4f7c4b,_0x2e1fda){const _0xa91b82=_0x4f7c4b['name'],_0x18864a=getFileName(_0x2e1fda['filename'],'.ts'),_0x46f992=constants['assertStringsToRemove']['reduce']((_0x33de9d,_0x54542c)=>_0x33de9d['replace'](_0x54542c,''),_0x18864a);!_0xa91b82['toLowerCase']()['includes'](_0x46f992)&&_0x2e1fda['report']({'node':_0x4f7c4b,'messageId':constants['messageIds']['mustUseFilenameInAssertFunctions'],'data':{'fileName':_0x18864a}});}__name(validateAssertFunctionName,'validateAssertFunctionName');const mustUseFilenameInAssertFunctions=createRule({'name':ruleName,'meta':constants['meta'],'defaultOptions':[],'create'(_0x1dee47){return {'FunctionDeclaration'(_0x3b8522){_0x3b8522['id']?.['name']['toLowerCase']()['includes'](constants['assertFunctionSubString'])&&validateAssertFunctionName(_0x3b8522['id'],_0x1dee47);},'VariableDeclarator'(_0x2c7c9c){_0x2c7c9c['id']['type']===nodeTypes['identifier']&&_0x2c7c9c['init']&&(_0x2c7c9c['init']['type']===nodeTypes['arrowFunctionExpression']||_0x2c7c9c['init']['type']===nodeTypes['functionExpression'])&&(_0x2c7c9c['id']['name']['toLowerCase']()['includes'](constants['assertFunctionSubString'])&&validateAssertFunctionName(_0x2c7c9c['id'],_0x1dee47));}};}});
6
7
 
7
- export { mustUseFilenameInAssertFunctions as default };
8
+ export { mustUseFilenameInAssertFunctions as default, ruleName };
@@ -1,3 +1,4 @@
1
1
  import { ESLintUtils } from "@typescript-eslint/utils";
2
+ export declare const ruleName = "must-use-func-declaration-for-named-func";
2
3
  declare const mustUseFuncDeclarationForNamedFunc: ESLintUtils.RuleModule<"mustUseFuncDeclarationForNamedFunc", [], unknown, ESLintUtils.RuleListener>;
3
4
  export default mustUseFuncDeclarationForNamedFunc;