@fenge/eslint-config 0.8.3 → 0.9.1

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.
@@ -331,12 +331,157 @@ export declare function getTsBase(): {
331
331
  readonly unicorn: import("eslint").ESLint.Plugin & {
332
332
  configs: {
333
333
  recommended: import("eslint").Linter.FlatConfig;
334
+ unopinionated: import("eslint").Linter.FlatConfig;
334
335
  all: import("eslint").Linter.FlatConfig;
335
336
  "flat/all": import("eslint").Linter.FlatConfig;
336
337
  "flat/recommended": import("eslint").Linter.FlatConfig;
337
338
  };
338
339
  };
339
- readonly "es-x": unknown;
340
+ readonly "es-x": {
341
+ meta: {
342
+ name: string;
343
+ version: string;
344
+ };
345
+ configs: {
346
+ "flat/no-array-grouping": import("eslint").Linter.Config;
347
+ "flat/no-arraybuffer-base64": import("eslint").Linter.Config;
348
+ "flat/no-change-array-by-copy": import("eslint").Linter.Config;
349
+ "flat/no-class-fields": import("eslint").Linter.Config;
350
+ "flat/no-explicit-resource-management": import("eslint").Linter.Config;
351
+ "flat/no-float16array": import("eslint").Linter.Config;
352
+ "flat/no-import-attributes": import("eslint").Linter.Config;
353
+ "flat/no-intl-locale-info": import("eslint").Linter.Config;
354
+ "flat/no-intl-numberformat-v3": import("eslint").Linter.Config;
355
+ "flat/no-is-usv-string": import("eslint").Linter.Config;
356
+ "flat/no-iterator-helpers": import("eslint").Linter.Config;
357
+ "flat/no-json-parse-with-source": import("eslint").Linter.Config;
358
+ "flat/no-new-in-es5": import("eslint").Linter.Config;
359
+ "flat/no-new-in-es2015": import("eslint").Linter.Config;
360
+ "flat/no-new-in-es2015-intl-api": import("eslint").Linter.Config;
361
+ "flat/no-new-in-es2016": import("eslint").Linter.Config;
362
+ "flat/no-new-in-es2016-intl-api": import("eslint").Linter.Config;
363
+ "flat/no-new-in-es2017": import("eslint").Linter.Config;
364
+ "flat/no-new-in-es2017-intl-api": import("eslint").Linter.Config;
365
+ "flat/no-new-in-es2018": import("eslint").Linter.Config;
366
+ "flat/no-new-in-es2018-intl-api": import("eslint").Linter.Config;
367
+ "flat/no-new-in-es2019": import("eslint").Linter.Config;
368
+ "flat/no-new-in-es2019-intl-api": import("eslint").Linter.Config;
369
+ "flat/no-new-in-es2020": import("eslint").Linter.Config;
370
+ "flat/no-new-in-es2020-intl-api": import("eslint").Linter.Config;
371
+ "flat/no-new-in-es2021": import("eslint").Linter.Config;
372
+ "flat/no-new-in-es2021-intl-api": import("eslint").Linter.Config;
373
+ "flat/no-new-in-es2022": import("eslint").Linter.Config;
374
+ "flat/no-new-in-es2022-intl-api": import("eslint").Linter.Config;
375
+ "flat/no-new-in-es2023": import("eslint").Linter.Config;
376
+ "flat/no-new-in-es2023-intl-api": import("eslint").Linter.Config;
377
+ "flat/no-new-in-es2024": import("eslint").Linter.Config;
378
+ "flat/no-new-in-es2024-intl-api": import("eslint").Linter.Config;
379
+ "flat/no-new-in-es2025": import("eslint").Linter.Config;
380
+ "flat/no-new-in-es2025-intl-api": import("eslint").Linter.Config;
381
+ "flat/no-new-in-esnext": import("eslint").Linter.Config;
382
+ "flat/no-new-in-esnext-intl-api": import("eslint").Linter.Config;
383
+ "flat/no-relative-indexing-method": import("eslint").Linter.Config;
384
+ "flat/no-set-methods": import("eslint").Linter.Config;
385
+ "flat/no-string-matchall": import("eslint").Linter.Config;
386
+ "flat/no-temporal": import("eslint").Linter.Config;
387
+ "flat/no-upsert": import("eslint").Linter.Config;
388
+ "flat/restrict-to-es-intl-api-1st-edition": import("eslint").Linter.Config;
389
+ "flat/restrict-to-es3": import("eslint").Linter.Config;
390
+ "flat/restrict-to-es5": import("eslint").Linter.Config;
391
+ "flat/restrict-to-es2015": import("eslint").Linter.Config;
392
+ "flat/restrict-to-es2015-intl-api": import("eslint").Linter.Config;
393
+ "flat/restrict-to-es2016": import("eslint").Linter.Config;
394
+ "flat/restrict-to-es2016-intl-api": import("eslint").Linter.Config;
395
+ "flat/restrict-to-es2017": import("eslint").Linter.Config;
396
+ "flat/restrict-to-es2017-intl-api": import("eslint").Linter.Config;
397
+ "flat/restrict-to-es2018": import("eslint").Linter.Config;
398
+ "flat/restrict-to-es2018-intl-api": import("eslint").Linter.Config;
399
+ "flat/restrict-to-es2019": import("eslint").Linter.Config;
400
+ "flat/restrict-to-es2019-intl-api": import("eslint").Linter.Config;
401
+ "flat/restrict-to-es2020": import("eslint").Linter.Config;
402
+ "flat/restrict-to-es2020-intl-api": import("eslint").Linter.Config;
403
+ "flat/restrict-to-es2021": import("eslint").Linter.Config;
404
+ "flat/restrict-to-es2021-intl-api": import("eslint").Linter.Config;
405
+ "flat/restrict-to-es2022": import("eslint").Linter.Config;
406
+ "flat/restrict-to-es2022-intl-api": import("eslint").Linter.Config;
407
+ "flat/restrict-to-es2023": import("eslint").Linter.Config;
408
+ "flat/restrict-to-es2023-intl-api": import("eslint").Linter.Config;
409
+ "flat/restrict-to-es2024": import("eslint").Linter.Config;
410
+ "flat/restrict-to-es2024-intl-api": import("eslint").Linter.Config;
411
+ "no-array-grouping": import("eslint").Linter.LegacyConfig;
412
+ "no-arraybuffer-base64": import("eslint").Linter.LegacyConfig;
413
+ "no-change-array-by-copy": import("eslint").Linter.LegacyConfig;
414
+ "no-class-fields": import("eslint").Linter.LegacyConfig;
415
+ "no-explicit-resource-management": import("eslint").Linter.LegacyConfig;
416
+ "no-float16array": import("eslint").Linter.LegacyConfig;
417
+ "no-import-attributes": import("eslint").Linter.LegacyConfig;
418
+ "no-intl-locale-info": import("eslint").Linter.LegacyConfig;
419
+ "no-intl-numberformat-v3": import("eslint").Linter.LegacyConfig;
420
+ "no-is-usv-string": import("eslint").Linter.LegacyConfig;
421
+ "no-iterator-helpers": import("eslint").Linter.LegacyConfig;
422
+ "no-json-parse-with-source": import("eslint").Linter.LegacyConfig;
423
+ "no-new-in-es5": import("eslint").Linter.LegacyConfig;
424
+ "no-new-in-es2015": import("eslint").Linter.LegacyConfig;
425
+ "no-new-in-es2015-intl-api": import("eslint").Linter.LegacyConfig;
426
+ "no-new-in-es2016": import("eslint").Linter.LegacyConfig;
427
+ "no-new-in-es2016-intl-api": import("eslint").Linter.LegacyConfig;
428
+ "no-new-in-es2017": import("eslint").Linter.LegacyConfig;
429
+ "no-new-in-es2017-intl-api": import("eslint").Linter.LegacyConfig;
430
+ "no-new-in-es2018": import("eslint").Linter.LegacyConfig;
431
+ "no-new-in-es2018-intl-api": import("eslint").Linter.LegacyConfig;
432
+ "no-new-in-es2019": import("eslint").Linter.LegacyConfig;
433
+ "no-new-in-es2019-intl-api": import("eslint").Linter.LegacyConfig;
434
+ "no-new-in-es2020": import("eslint").Linter.LegacyConfig;
435
+ "no-new-in-es2020-intl-api": import("eslint").Linter.LegacyConfig;
436
+ "no-new-in-es2021": import("eslint").Linter.LegacyConfig;
437
+ "no-new-in-es2021-intl-api": import("eslint").Linter.LegacyConfig;
438
+ "no-new-in-es2022": import("eslint").Linter.LegacyConfig;
439
+ "no-new-in-es2022-intl-api": import("eslint").Linter.LegacyConfig;
440
+ "no-new-in-es2023": import("eslint").Linter.LegacyConfig;
441
+ "no-new-in-es2023-intl-api": import("eslint").Linter.LegacyConfig;
442
+ "no-new-in-es2024": import("eslint").Linter.LegacyConfig;
443
+ "no-new-in-es2024-intl-api": import("eslint").Linter.LegacyConfig;
444
+ "no-new-in-es2025": import("eslint").Linter.LegacyConfig;
445
+ "no-new-in-es2025-intl-api": import("eslint").Linter.LegacyConfig;
446
+ "no-new-in-esnext": import("eslint").Linter.LegacyConfig;
447
+ "no-new-in-esnext-intl-api": import("eslint").Linter.LegacyConfig;
448
+ "no-relative-indexing-method": import("eslint").Linter.LegacyConfig;
449
+ "no-set-methods": import("eslint").Linter.LegacyConfig;
450
+ "no-string-matchall": import("eslint").Linter.LegacyConfig;
451
+ "no-temporal": import("eslint").Linter.LegacyConfig;
452
+ "no-upsert": import("eslint").Linter.LegacyConfig;
453
+ "restrict-to-es-intl-api-1st-edition": import("eslint").Linter.LegacyConfig;
454
+ "restrict-to-es3": import("eslint").Linter.LegacyConfig;
455
+ "restrict-to-es5": import("eslint").Linter.LegacyConfig;
456
+ "restrict-to-es2015": import("eslint").Linter.LegacyConfig;
457
+ "restrict-to-es2015-intl-api": import("eslint").Linter.LegacyConfig;
458
+ "restrict-to-es2016": import("eslint").Linter.LegacyConfig;
459
+ "restrict-to-es2016-intl-api": import("eslint").Linter.LegacyConfig;
460
+ "restrict-to-es2017": import("eslint").Linter.LegacyConfig;
461
+ "restrict-to-es2017-intl-api": import("eslint").Linter.LegacyConfig;
462
+ "restrict-to-es2018": import("eslint").Linter.LegacyConfig;
463
+ "restrict-to-es2018-intl-api": import("eslint").Linter.LegacyConfig;
464
+ "restrict-to-es2019": import("eslint").Linter.LegacyConfig;
465
+ "restrict-to-es2019-intl-api": import("eslint").Linter.LegacyConfig;
466
+ "restrict-to-es2020": import("eslint").Linter.LegacyConfig;
467
+ "restrict-to-es2020-intl-api": import("eslint").Linter.LegacyConfig;
468
+ "restrict-to-es2021": import("eslint").Linter.LegacyConfig;
469
+ "restrict-to-es2021-intl-api": import("eslint").Linter.LegacyConfig;
470
+ "restrict-to-es2022": import("eslint").Linter.LegacyConfig;
471
+ "restrict-to-es2022-intl-api": import("eslint").Linter.LegacyConfig;
472
+ "restrict-to-es2023": import("eslint").Linter.LegacyConfig;
473
+ "restrict-to-es2023-intl-api": import("eslint").Linter.LegacyConfig;
474
+ "restrict-to-es2024": import("eslint").Linter.LegacyConfig;
475
+ "restrict-to-es2024-intl-api": import("eslint").Linter.LegacyConfig;
476
+ readonly "no-5": import("eslint").Linter.LegacyConfig;
477
+ readonly "no-2015": import("eslint").Linter.LegacyConfig;
478
+ readonly "no-2016": import("eslint").Linter.LegacyConfig;
479
+ readonly "no-2017": import("eslint").Linter.LegacyConfig;
480
+ readonly "no-2018": import("eslint").Linter.LegacyConfig;
481
+ readonly "no-2019": import("eslint").Linter.LegacyConfig;
482
+ };
483
+ rules: Record<string, import("eslint").Rule.RuleModule>;
484
+ };
340
485
  readonly "eslint-comments": typeof import("@eslint-community/eslint-plugin-eslint-comments");
341
486
  readonly esm: typeof import("eslint-plugin-esm");
342
487
  readonly "simple-import-sort": import("eslint").ESLint.Plugin;
@@ -476,63 +621,29 @@ export declare function getTsBase(): {
476
621
  readonly "@typescript-eslint/unbound-method": "error";
477
622
  readonly "@typescript-eslint/unified-signatures": "error";
478
623
  readonly "@typescript-eslint/use-unknown-in-catch-callback-variable": "error";
479
- readonly "default-param-last": "off";
480
- readonly "init-declarations": "off";
481
- readonly "max-params": "off";
482
- readonly "no-empty-function": "off";
483
- readonly "no-invalid-this": "off";
484
- readonly "no-shadow": "off";
485
- readonly "no-useless-constructor": "off";
486
624
  readonly "require-await": "off";
487
- readonly "no-array-constructor": "off";
488
- readonly "no-dupe-class-members": "off";
489
625
  readonly "no-implied-eval": "off";
490
626
  readonly "no-redeclare": "off";
491
627
  readonly "no-throw-literal": "off";
492
- readonly "no-unused-expressions": "off";
493
628
  readonly "no-unused-vars": "off";
494
- readonly "no-use-before-define": "off";
495
629
  readonly "prefer-promise-reject-errors": "off";
496
- readonly "@typescript-eslint/default-param-last": "error";
497
- readonly "@typescript-eslint/init-declarations": "error";
498
- readonly "@typescript-eslint/max-params": readonly ["error", {
499
- readonly max: 4;
500
- }];
501
- readonly "@typescript-eslint/no-array-constructor": "error";
502
- readonly "@typescript-eslint/no-dupe-class-members": "error";
503
- readonly "@typescript-eslint/no-empty-function": "error";
504
630
  readonly "@typescript-eslint/no-implied-eval": "error";
505
- readonly "@typescript-eslint/no-invalid-this": "error";
506
631
  readonly "@typescript-eslint/no-redeclare": readonly ["error", {
507
632
  readonly builtinGlobals: false;
508
633
  }];
509
- readonly "@typescript-eslint/no-shadow": readonly ["error", {
510
- readonly ignoreOnInitialization: true;
511
- }];
512
- readonly "@typescript-eslint/no-unused-expressions": readonly ["error", {
513
- readonly enforceForJSX: true;
514
- readonly allowShortCircuit: true;
515
- readonly allowTernary: true;
516
- readonly allowTaggedTemplates: true;
517
- }];
518
634
  readonly "@typescript-eslint/no-unused-vars": readonly ["error", {
519
635
  readonly args: "none";
520
636
  readonly caughtErrors: "none";
521
637
  readonly ignoreRestSiblings: true;
522
638
  readonly vars: "all";
523
639
  }];
524
- readonly "@typescript-eslint/no-use-before-define": readonly ["error", {
525
- readonly functions: false;
526
- readonly classes: false;
527
- readonly variables: false;
528
- }];
529
- readonly "@typescript-eslint/no-useless-constructor": "error";
530
640
  readonly "@typescript-eslint/prefer-promise-reject-errors": "error";
531
641
  readonly "@typescript-eslint/require-await": "error";
532
642
  readonly "arrow-body-style": readonly ["error", "as-needed"];
533
643
  readonly "simple-import-sort/exports": "error";
534
644
  readonly "unicorn/prefer-node-protocol": "error";
535
645
  readonly "unicorn/escape-case": "error";
646
+ readonly "default-param-last": "error";
536
647
  readonly "for-direction": "error";
537
648
  readonly "func-name-matching": "error";
538
649
  readonly "func-names": "error";
@@ -540,18 +651,23 @@ export declare function getTsBase(): {
540
651
  readonly allowArrowFunctions: true;
541
652
  }];
542
653
  readonly "getter-return": "error";
654
+ readonly "init-declarations": "error";
543
655
  readonly "logical-assignment-operators": readonly ["error", "always", {
544
656
  readonly enforceForIfStatements: true;
545
657
  }];
546
658
  readonly "max-depth": readonly ["error", {
547
659
  readonly max: 5;
548
660
  }];
661
+ readonly "max-params": readonly ["error", {
662
+ readonly max: 4;
663
+ }];
549
664
  readonly "no-bitwise": "error";
550
665
  readonly "no-console": "error";
551
666
  readonly "no-constant-binary-expression": "error";
552
667
  readonly "no-dupe-else-if": "error";
553
668
  readonly "no-duplicate-imports": "error";
554
669
  readonly "no-empty-static-block": "error";
670
+ readonly "no-empty-function": "error";
555
671
  readonly "no-implicit-coercion": readonly ["error", {
556
672
  readonly disallowTemplateShorthand: true;
557
673
  readonly allow: readonly ["!!"];
@@ -559,6 +675,7 @@ export declare function getTsBase(): {
559
675
  readonly "no-inner-declarations": readonly ["error", "functions", {
560
676
  readonly blockScopedFunctions: "disallow";
561
677
  }];
678
+ readonly "no-invalid-this": "error";
562
679
  readonly "no-lonely-if": "error";
563
680
  readonly "no-multi-assign": "error";
564
681
  readonly "no-new-native-nonconstructor": "error";
@@ -567,6 +684,10 @@ export declare function getTsBase(): {
567
684
  readonly "no-param-reassign": "error";
568
685
  readonly "no-plusplus": "error";
569
686
  readonly "no-setter-return": "error";
687
+ readonly "no-shadow": readonly ["error", {
688
+ readonly ignoreOnInitialization: true;
689
+ }];
690
+ readonly "no-unassigned-vars": "error";
570
691
  readonly "no-unsafe-optional-chaining": readonly ["error", {
571
692
  readonly disallowArithmeticOperators: true;
572
693
  }];
@@ -576,6 +697,7 @@ export declare function getTsBase(): {
576
697
  readonly "no-useless-call": "error";
577
698
  readonly "no-useless-catch": "error";
578
699
  readonly "no-useless-computed-key": "error";
700
+ readonly "no-useless-constructor": "error";
579
701
  readonly "no-useless-escape": "error";
580
702
  readonly "no-useless-rename": "error";
581
703
  readonly "no-useless-return": "error";
@@ -797,6 +919,12 @@ export declare function getTsBase(): {
797
919
  readonly "unicorn/no-accessor-recursion": "error";
798
920
  readonly "unicorn/no-array-callback-reference": "error";
799
921
  readonly "unicorn/no-array-method-this-argument": "error";
922
+ readonly "unicorn/no-array-reverse": readonly ["error", {
923
+ readonly allowExpressionStatement: false;
924
+ }];
925
+ readonly "unicorn/no-array-sort": readonly ["error", {
926
+ readonly allowExpressionStatement: false;
927
+ }];
800
928
  readonly "unicorn/no-await-in-promise-methods": "error";
801
929
  readonly "unicorn/no-for-loop": "error";
802
930
  readonly "unicorn/no-instanceof-builtins": "error";
@@ -815,15 +943,20 @@ export declare function getTsBase(): {
815
943
  readonly "unicorn/no-unnecessary-await": "error";
816
944
  readonly "unicorn/no-unreadable-array-destructuring": "error";
817
945
  readonly "unicorn/no-unreadable-iife": "error";
946
+ readonly "unicorn/no-useless-error-capture-stack-trace": "error";
818
947
  readonly "unicorn/no-useless-fallback-in-spread": "error";
819
948
  readonly "unicorn/no-useless-promise-resolve-reject": "error";
820
949
  readonly "unicorn/no-useless-spread": "error";
821
950
  readonly "unicorn/no-useless-switch-case": "error";
822
951
  readonly "unicorn/no-zero-fractions": "error";
823
952
  readonly "unicorn/prefer-array-flat-map": "error";
953
+ readonly "unicorn/prefer-bigint-literals": "error";
954
+ readonly "unicorn/prefer-class-fields": "error";
955
+ readonly "unicorn/prefer-classlist-toggle": "error";
824
956
  readonly "unicorn/prefer-date-now": "error";
825
957
  readonly "unicorn/prefer-export-from": "error";
826
958
  readonly "unicorn/prefer-global-this": "error";
959
+ readonly "unicorn/prefer-import-meta-properties": "error";
827
960
  readonly "unicorn/prefer-includes": "error";
828
961
  readonly "unicorn/prefer-logical-operator-over-ternary": "error";
829
962
  readonly "unicorn/prefer-math-min-max": "error";
@@ -839,6 +972,8 @@ export declare function getTsBase(): {
839
972
  readonly "unicorn/prefer-string-slice": "error";
840
973
  readonly "unicorn/prefer-ternary": "error";
841
974
  readonly "unicorn/require-array-join-separator": "error";
975
+ readonly "unicorn/require-module-attributes": "error";
976
+ readonly "unicorn/require-module-specifiers": "error";
842
977
  readonly "unicorn/require-number-to-fixed-digits-argument": "error";
843
978
  readonly "unicorn/text-encoding-identifier-case": "error";
844
979
  readonly "unicorn/throw-new-error": "error";
@@ -852,6 +987,7 @@ export declare function getTsBase(): {
852
987
  readonly "@fenge/no-top-level-arrow-function": "error";
853
988
  readonly "@fenge/no-triple-slash-directive": "error";
854
989
  readonly "@fenge/no-unnecessary-template-string": "error";
990
+ readonly "@fenge/no-used-underscore-param": "error";
855
991
  readonly "@typescript-eslint/ban-ts-comment": readonly ["error", {
856
992
  readonly "ts-expect-error": true;
857
993
  readonly "ts-ignore": true;
@@ -883,6 +1019,7 @@ export declare function getTsBase(): {
883
1019
  readonly capIsNew: false;
884
1020
  readonly properties: true;
885
1021
  }];
1022
+ readonly "no-array-constructor": "error";
886
1023
  readonly "no-async-promise-executor": "error";
887
1024
  readonly "no-caller": "error";
888
1025
  readonly "no-case-declarations": "error";
@@ -897,6 +1034,7 @@ export declare function getTsBase(): {
897
1034
  readonly "no-debugger": "error";
898
1035
  readonly "no-delete-var": "error";
899
1036
  readonly "no-dupe-args": "error";
1037
+ readonly "no-dupe-class-members": "error";
900
1038
  readonly "no-dupe-keys": "error";
901
1039
  readonly "no-duplicate-case": "error";
902
1040
  readonly "no-useless-backreference": "error";
@@ -954,6 +1092,17 @@ export declare function getTsBase(): {
954
1092
  readonly "no-unreachable-loop": "error";
955
1093
  readonly "no-unsafe-finally": "error";
956
1094
  readonly "no-unsafe-negation": "error";
1095
+ readonly "no-unused-expressions": readonly ["error", {
1096
+ readonly enforceForJSX: true;
1097
+ readonly allowShortCircuit: true;
1098
+ readonly allowTernary: true;
1099
+ readonly allowTaggedTemplates: true;
1100
+ }];
1101
+ readonly "no-use-before-define": readonly ["error", {
1102
+ readonly functions: false;
1103
+ readonly classes: false;
1104
+ readonly variables: false;
1105
+ }];
957
1106
  readonly "no-void": "error";
958
1107
  readonly "no-with": "error";
959
1108
  readonly "one-var": readonly ["error", {
@@ -1 +1 @@
1
- {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../src/config/ts/base.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,aAAa,MAAM,yBAAyB,CAAC;AAGzD,wBAAgB,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAoQxB"}
1
+ {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../src/config/ts/base.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,aAAa,MAAM,yBAAyB,CAAC;AAGzD,wBAAgB,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqQxB"}
@@ -5,28 +5,29 @@ export function getTsBase() {
5
5
  const getTsExtensionRules = () => {
6
6
  // Key is js rule, value is ts rule
7
7
  // https://typescript-eslint.io/rules/?=extension
8
+ // Some rules are implemented by eslint core, so we comment them out.
8
9
  const extensionRuleMap = {
9
- "class-methods-use-this": "@typescript-eslint/class-methods-use-this",
10
+ // "class-methods-use-this": "@typescript-eslint/class-methods-use-this", // 9.23.0
10
11
  "consistent-return": "@typescript-eslint/consistent-return",
11
- "default-param-last": "@typescript-eslint/default-param-last",
12
+ // "default-param-last": "@typescript-eslint/default-param-last", // 9.23.0
12
13
  "dot-notation": "@typescript-eslint/dot-notation",
13
- "init-declarations": "@typescript-eslint/init-declarations",
14
- "max-params": "@typescript-eslint/max-params",
15
- "no-array-constructor": "@typescript-eslint/no-array-constructor",
16
- "no-dupe-class-members": "@typescript-eslint/no-dupe-class-members",
17
- "no-empty-function": "@typescript-eslint/no-empty-function",
14
+ // "init-declarations": "@typescript-eslint/init-declarations", // 9.24.0
15
+ // "max-params": "@typescript-eslint/max-params", // 9.27.0
16
+ // "no-array-constructor": "@typescript-eslint/no-array-constructor", // 9.24.0
17
+ // "no-dupe-class-members": "@typescript-eslint/no-dupe-class-members", // 9.24.0
18
+ // "no-empty-function": "@typescript-eslint/no-empty-function", // 9.25.0
18
19
  "no-implied-eval": "@typescript-eslint/no-implied-eval",
19
- "no-invalid-this": "@typescript-eslint/no-invalid-this",
20
- "no-loop-func": "@typescript-eslint/no-loop-func",
21
- // "no-loss-of-precision": "@typescript-eslint/no-loss-of-precision", // This rule has been deprecated
22
- "no-magic-numbers": "@typescript-eslint/no-magic-numbers",
20
+ // "no-invalid-this": "@typescript-eslint/no-invalid-this", // 9.25.0
21
+ // "no-loop-func": "@typescript-eslint/no-loop-func", // 9.25.0
22
+ // "no-loss-of-precision": "@typescript-eslint/no-loss-of-precision", // 9.24.0. And this rule has been deprecated
23
+ // "no-magic-numbers": "@typescript-eslint/no-magic-numbers", // 9.28.0
23
24
  "no-redeclare": "@typescript-eslint/no-redeclare",
24
25
  "no-restricted-imports": "@typescript-eslint/no-restricted-imports",
25
- "no-shadow": "@typescript-eslint/no-shadow",
26
- "no-unused-expressions": "@typescript-eslint/no-unused-expressions",
26
+ // "no-shadow": "@typescript-eslint/no-shadow", // 9.28.0
27
+ // "no-unused-expressions": "@typescript-eslint/no-unused-expressions", // 9.25.0
27
28
  "no-unused-vars": "@typescript-eslint/no-unused-vars",
28
- "no-use-before-define": "@typescript-eslint/no-use-before-define",
29
- "no-useless-constructor": "@typescript-eslint/no-useless-constructor",
29
+ // "no-use-before-define": "@typescript-eslint/no-use-before-define", // 9.28.0
30
+ // "no-useless-constructor": "@typescript-eslint/no-useless-constructor", // 9.23.0
30
31
  "no-throw-literal": "@typescript-eslint/only-throw-error",
31
32
  "prefer-destructuring": "@typescript-eslint/prefer-destructuring",
32
33
  "prefer-promise-reject-errors": "@typescript-eslint/prefer-promise-reject-errors",
@@ -232,4 +233,4 @@ export function getTsBase() {
232
233
  },
233
234
  };
234
235
  }
235
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../src/config/ts/base.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fengeTsPlugin from \"@fenge/eslint-plugin-ts\";\nimport { getJsBase } from \"../js/base.ts\";\n\nexport function getTsBase() {\n  const jsBase = getJsBase();\n\n  const getTsExtensionRules = () => {\n    // Key is js rule, value is ts rule\n    // https://typescript-eslint.io/rules/?=extension\n    const extensionRuleMap = {\n      \"class-methods-use-this\": \"@typescript-eslint/class-methods-use-this\",\n      \"consistent-return\": \"@typescript-eslint/consistent-return\",\n      \"default-param-last\": \"@typescript-eslint/default-param-last\",\n      \"dot-notation\": \"@typescript-eslint/dot-notation\",\n      \"init-declarations\": \"@typescript-eslint/init-declarations\",\n      \"max-params\": \"@typescript-eslint/max-params\",\n      \"no-array-constructor\": \"@typescript-eslint/no-array-constructor\",\n      \"no-dupe-class-members\": \"@typescript-eslint/no-dupe-class-members\",\n      \"no-empty-function\": \"@typescript-eslint/no-empty-function\",\n      \"no-implied-eval\": \"@typescript-eslint/no-implied-eval\",\n      \"no-invalid-this\": \"@typescript-eslint/no-invalid-this\",\n      \"no-loop-func\": \"@typescript-eslint/no-loop-func\",\n      // \"no-loss-of-precision\": \"@typescript-eslint/no-loss-of-precision\", // This rule has been deprecated\n      \"no-magic-numbers\": \"@typescript-eslint/no-magic-numbers\",\n      \"no-redeclare\": \"@typescript-eslint/no-redeclare\",\n      \"no-restricted-imports\": \"@typescript-eslint/no-restricted-imports\",\n      \"no-shadow\": \"@typescript-eslint/no-shadow\",\n      \"no-unused-expressions\": \"@typescript-eslint/no-unused-expressions\",\n      \"no-unused-vars\": \"@typescript-eslint/no-unused-vars\",\n      \"no-use-before-define\": \"@typescript-eslint/no-use-before-define\",\n      \"no-useless-constructor\": \"@typescript-eslint/no-useless-constructor\",\n      \"no-throw-literal\": \"@typescript-eslint/only-throw-error\",\n      \"prefer-destructuring\": \"@typescript-eslint/prefer-destructuring\",\n      \"prefer-promise-reject-errors\":\n        \"@typescript-eslint/prefer-promise-reject-errors\",\n      \"require-await\": \"@typescript-eslint/require-await\",\n      \"no-return-await\": \"@typescript-eslint/return-await\", // no-return-await has been deprecated\n    } as const;\n\n    type Js2TsRuleMap = typeof extensionRuleMap;\n    type Ts2JsRuleMap = {\n      [K in keyof Js2TsRuleMap as Js2TsRuleMap[K]]: K; // reverse\n    };\n\n    type JsExtensionKey = Extract<\n      keyof Js2TsRuleMap,\n      keyof typeof jsBase.rules\n    >; // Extract\n    type TsExtensionKey = Js2TsRuleMap[JsExtensionKey];\n\n    type JsResult = Record<JsExtensionKey, \"off\">;\n    type TsResult = {\n      [Key in TsExtensionKey]: (typeof jsBase.rules)[Ts2JsRuleMap[Key]];\n    };\n    type Result = JsResult & TsResult;\n\n    const isInExtensionRuleMap = (\n      key: string,\n    ): key is keyof typeof extensionRuleMap => key in extensionRuleMap;\n    return Object.entries(jsBase.rules).reduce(\n      (result, [jsRuleKey, jsRuleValue]) =>\n        isInExtensionRuleMap(jsRuleKey)\n          ? {\n              ...result,\n              [jsRuleKey]: \"off\",\n              [extensionRuleMap[jsRuleKey]]: jsRuleValue,\n            }\n          : result,\n      {} as Result,\n    );\n  };\n\n  return {\n    ...jsBase,\n    name: \"fenge/typescript\",\n    files: [\"**/*.{ts,cts,mts,tsx}\"],\n    languageOptions: {\n      ...jsBase.languageOptions,\n      parserOptions: {\n        ...jsBase.languageOptions.parserOptions,\n        // Setting `projectService: true` or `project: true` is pretty slow when lint a monorepo with many tsconfig.json files in each sub-app.\n        // But setting `project: \"tsconfig.json\"` will cause parser error when the project root tsconfig.json is `{ extends: \"fenge/tsconfig\" }`\n        projectService: true,\n      },\n      globals: {\n        ...jsBase.languageOptions.globals,\n        NodeJS: false,\n      },\n    },\n    plugins: {\n      ...jsBase.plugins,\n      \"@fenge-ts\": fengeTsPlugin,\n    },\n    rules: {\n      ...jsBase.rules,\n      ...getTsExtensionRules(),\n\n      // fenge\n      \"@fenge-ts/exact-map-set-type\": \"error\",\n      \"@fenge-ts/no-const-enum\": \"error\",\n      \"@fenge-ts/no-declares\": \"error\",\n      \"@fenge-ts/no-export-assignment\": \"error\",\n      \"@fenge-ts/no-misuse-spreading-parameter\": \"error\",\n      \"@fenge-ts/no-property-decorator\": \"error\",\n      \"@fenge-ts/no-untyped-empty-array\": \"error\",\n      // typescript\n      \"@typescript-eslint/adjacent-overload-signatures\": \"error\",\n      // \"@typescript-eslint/array-type\": [\"error\", 'array-simple'], // The default option is 'array'. Not very sure if we need to change the option. So disabled it.\n      \"@typescript-eslint/await-thenable\": \"error\",\n      \"@typescript-eslint/class-literal-property-style\": \"error\",\n      \"@typescript-eslint/consistent-generic-constructors\": \"error\",\n      \"@typescript-eslint/consistent-indexed-object-style\": \"error\",\n      \"@typescript-eslint/consistent-type-assertions\": [\n        \"error\",\n        {\n          assertionStyle: \"as\",\n          objectLiteralTypeAssertions: \"allow-as-parameter\",\n        },\n      ],\n      \"@typescript-eslint/consistent-type-definitions\": [\"error\", \"interface\"], // TODO should we change to 'type'?\n      \"@typescript-eslint/consistent-type-exports\": \"error\",\n      \"@typescript-eslint/consistent-type-imports\": \"error\",\n      \"@typescript-eslint/dot-notation\": [\"error\", { allowKeywords: true }],\n      \"@typescript-eslint/method-signature-style\": \"error\",\n      \"@typescript-eslint/naming-convention\": [\n        \"error\",\n        {\n          selector: \"function\",\n          format: [\"camelCase\", \"PascalCase\"],\n        },\n        {\n          selector: \"variable\",\n          types: [\"function\"],\n          format: [\"camelCase\", \"PascalCase\"], // decorators need PascalCase\n        },\n        {\n          selector: \"class\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"interface\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"typeAlias\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"typeParameter\",\n          format: [\"UPPER_CASE\", \"PascalCase\"],\n        },\n      ],\n      \"@typescript-eslint/no-array-delete\": \"error\",\n      \"@typescript-eslint/no-base-to-string\": [\n        \"error\",\n        { ignoredTypeNames: [] },\n      ],\n      \"@typescript-eslint/no-confusing-non-null-assertion\": \"error\",\n      \"@typescript-eslint/no-confusing-void-expression\": [\n        \"error\",\n        { ignoreArrowShorthand: true },\n      ],\n      \"@typescript-eslint/no-deprecated\": \"error\",\n      \"@typescript-eslint/no-duplicate-enum-values\": \"error\",\n      \"@typescript-eslint/no-duplicate-type-constituents\": \"error\",\n      \"@typescript-eslint/no-empty-object-type\": \"error\",\n      // \"@typescript-eslint/no-explicit-any\": \"warn\",\n      \"@typescript-eslint/no-extra-non-null-assertion\": \"error\",\n      // \"@typescript-eslint/no-extraneous-class\": \"error\", // Classes have only static member is reasonable sometimes. Nestjs modules use it a lot.\n      \"@typescript-eslint/no-floating-promises\": [\n        \"error\",\n        {\n          ignoreVoid: false,\n        },\n      ],\n      \"@typescript-eslint/no-for-in-array\": \"error\",\n      \"@typescript-eslint/no-import-type-side-effects\": \"error\",\n      \"@typescript-eslint/no-inferrable-types\": \"error\",\n      \"@typescript-eslint/no-invalid-void-type\": \"error\",\n      \"@typescript-eslint/no-misused-new\": \"error\",\n      \"@typescript-eslint/no-misused-promises\": \"error\",\n      \"@typescript-eslint/no-misused-spread\": \"error\",\n      \"@typescript-eslint/no-mixed-enums\": \"error\",\n      \"@typescript-eslint/no-namespace\": [\n        \"error\",\n        { allowDefinitionFiles: false },\n      ],\n      \"@typescript-eslint/no-non-null-asserted-nullish-coalescing\": \"error\",\n      \"@typescript-eslint/no-non-null-asserted-optional-chain\": \"error\",\n      \"@typescript-eslint/no-non-null-assertion\": \"error\",\n      \"@typescript-eslint/no-redundant-type-constituents\": \"error\",\n      \"@typescript-eslint/no-require-imports\": \"error\",\n      \"@typescript-eslint/no-unnecessary-boolean-literal-compare\": \"error\",\n      \"@typescript-eslint/no-unnecessary-condition\": [\n        \"error\",\n        // TODO: If https://github.com/typescript-eslint/typescript-eslint/issues/11978 is fixed, change to `allowConstantLoopConditions: \"only-allowed-literals\"`.\n        { allowConstantLoopConditions: \"always\" },\n      ],\n      \"@typescript-eslint/no-unnecessary-parameter-property-assignment\":\n        \"error\",\n      \"@typescript-eslint/no-unnecessary-template-expression\": \"error\", // js also need this rule\n      \"@typescript-eslint/no-unnecessary-type-arguments\": \"error\",\n      \"@typescript-eslint/no-unnecessary-type-assertion\": \"error\",\n      \"@typescript-eslint/no-unnecessary-type-constraint\": \"error\",\n      \"@typescript-eslint/no-unnecessary-type-conversion\": \"error\",\n      \"@typescript-eslint/no-unsafe-call\": \"error\",\n      \"@typescript-eslint/no-unsafe-declaration-merging\": \"error\",\n      \"@typescript-eslint/no-unsafe-enum-comparison\": \"error\",\n      \"@typescript-eslint/no-unsafe-function-type\": \"error\",\n      \"@typescript-eslint/no-unsafe-return\": \"error\", // This rule is not very perfect. See https://github.com/typescript-eslint/typescript-eslint/issues/10439\n      \"@typescript-eslint/no-unsafe-unary-minus\": \"error\",\n      \"@typescript-eslint/no-useless-default-assignment\": \"error\",\n      \"@typescript-eslint/no-wrapper-object-types\": \"error\",\n      \"@typescript-eslint/non-nullable-type-assertion-style\": \"error\",\n      \"@typescript-eslint/only-throw-error\": [\n        \"error\",\n        { allowThrowingUnknown: false },\n      ],\n      \"@typescript-eslint/prefer-as-const\": \"error\",\n      \"@typescript-eslint/prefer-function-type\": \"error\",\n      \"@typescript-eslint/prefer-includes\": \"error\",\n      \"@typescript-eslint/prefer-literal-enum-member\": \"error\",\n      \"@typescript-eslint/prefer-namespace-keyword\": \"error\",\n      \"@typescript-eslint/prefer-nullish-coalescing\": \"error\",\n      \"@typescript-eslint/prefer-optional-chain\": \"error\",\n      \"@typescript-eslint/prefer-readonly\": \"error\",\n      \"@typescript-eslint/prefer-regexp-exec\": \"error\",\n      \"@typescript-eslint/prefer-return-this-type\": \"error\",\n      \"@typescript-eslint/promise-function-async\": \"error\",\n      \"@typescript-eslint/restrict-plus-operands\": [\n        \"error\",\n        {\n          // allowAny: false,\n          allowBoolean: false,\n          allowNullish: false,\n          allowNumberAndString: false,\n          allowRegExp: false,\n          skipCompoundAssignments: false,\n        },\n      ],\n      \"@typescript-eslint/restrict-template-expressions\": [\n        \"error\",\n        {\n          allow: [],\n          // allowAny: false,\n          allowBoolean: false,\n          allowNever: false,\n          allowNullish: false,\n          // allowNumber: false,\n          allowRegExp: false,\n        },\n      ],\n      \"@typescript-eslint/related-getter-setter-pairs\": \"error\",\n      \"@typescript-eslint/return-await\": [\"error\", \"always\"],\n      \"@typescript-eslint/switch-exhaustiveness-check\": [\n        \"error\",\n        { requireDefaultForNonUnion: true },\n      ],\n      \"@typescript-eslint/unbound-method\": \"error\",\n      \"@typescript-eslint/unified-signatures\": \"error\",\n      \"@typescript-eslint/use-unknown-in-catch-callback-variable\": \"error\",\n    },\n  } as const;\n}\n"]}
236
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../src/config/ts/base.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,aAAa,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE1C,MAAM,UAAU,SAAS;IACvB,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAE3B,MAAM,mBAAmB,GAAG,GAAG,EAAE;QAC/B,mCAAmC;QACnC,iDAAiD;QACjD,qEAAqE;QACrE,MAAM,gBAAgB,GAAG;YACvB,mFAAmF;YACnF,mBAAmB,EAAE,sCAAsC;YAC3D,2EAA2E;YAC3E,cAAc,EAAE,iCAAiC;YACjD,yEAAyE;YACzE,2DAA2D;YAC3D,+EAA+E;YAC/E,iFAAiF;YACjF,yEAAyE;YACzE,iBAAiB,EAAE,oCAAoC;YACvD,qEAAqE;YACrE,+DAA+D;YAC/D,kHAAkH;YAClH,uEAAuE;YACvE,cAAc,EAAE,iCAAiC;YACjD,uBAAuB,EAAE,0CAA0C;YACnE,yDAAyD;YACzD,iFAAiF;YACjF,gBAAgB,EAAE,mCAAmC;YACrD,+EAA+E;YAC/E,mFAAmF;YACnF,kBAAkB,EAAE,qCAAqC;YACzD,sBAAsB,EAAE,yCAAyC;YACjE,8BAA8B,EAC5B,iDAAiD;YACnD,eAAe,EAAE,kCAAkC;YACnD,iBAAiB,EAAE,iCAAiC,EAAE,sCAAsC;SACpF,CAAC;QAmBX,MAAM,oBAAoB,GAAG,CAC3B,GAAW,EAC2B,EAAE,CAAC,GAAG,IAAI,gBAAgB,CAAC;QACnE,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,CACxC,CAAC,MAAM,EAAE,CAAC,SAAS,EAAE,WAAW,CAAC,EAAE,EAAE,CACnC,oBAAoB,CAAC,SAAS,CAAC;YAC7B,CAAC,CAAC;gBACE,GAAG,MAAM;gBACT,CAAC,SAAS,CAAC,EAAE,KAAK;gBAClB,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,EAAE,WAAW;aAC3C;YACH,CAAC,CAAC,MAAM,EACZ,EAAY,CACb,CAAC;IACJ,CAAC,CAAC;IAEF,OAAO;QACL,GAAG,MAAM;QACT,IAAI,EAAE,kBAAkB;QACxB,KAAK,EAAE,CAAC,uBAAuB,CAAC;QAChC,eAAe,EAAE;YACf,GAAG,MAAM,CAAC,eAAe;YACzB,aAAa,EAAE;gBACb,GAAG,MAAM,CAAC,eAAe,CAAC,aAAa;gBACvC,uIAAuI;gBACvI,wIAAwI;gBACxI,cAAc,EAAE,IAAI;aACrB;YACD,OAAO,EAAE;gBACP,GAAG,MAAM,CAAC,eAAe,CAAC,OAAO;gBACjC,MAAM,EAAE,KAAK;aACd;SACF;QACD,OAAO,EAAE;YACP,GAAG,MAAM,CAAC,OAAO;YACjB,WAAW,EAAE,aAAa;SAC3B;QACD,KAAK,EAAE;YACL,GAAG,MAAM,CAAC,KAAK;YACf,GAAG,mBAAmB,EAAE;YAExB,QAAQ;YACR,8BAA8B,EAAE,OAAO;YACvC,yBAAyB,EAAE,OAAO;YAClC,uBAAuB,EAAE,OAAO;YAChC,gCAAgC,EAAE,OAAO;YACzC,yCAAyC,EAAE,OAAO;YAClD,iCAAiC,EAAE,OAAO;YAC1C,kCAAkC,EAAE,OAAO;YAC3C,aAAa;YACb,iDAAiD,EAAE,OAAO;YAC1D,+JAA+J;YAC/J,mCAAmC,EAAE,OAAO;YAC5C,iDAAiD,EAAE,OAAO;YAC1D,oDAAoD,EAAE,OAAO;YAC7D,oDAAoD,EAAE,OAAO;YAC7D,+CAA+C,EAAE;gBAC/C,OAAO;gBACP;oBACE,cAAc,EAAE,IAAI;oBACpB,2BAA2B,EAAE,oBAAoB;iBAClD;aACF;YACD,gDAAgD,EAAE,CAAC,OAAO,EAAE,WAAW,CAAC,EAAE,mCAAmC;YAC7G,4CAA4C,EAAE,OAAO;YACrD,4CAA4C,EAAE,OAAO;YACrD,iCAAiC,EAAE,CAAC,OAAO,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;YACrE,2CAA2C,EAAE,OAAO;YACpD,sCAAsC,EAAE;gBACtC,OAAO;gBACP;oBACE,QAAQ,EAAE,UAAU;oBACpB,MAAM,EAAE,CAAC,WAAW,EAAE,YAAY,CAAC;iBACpC;gBACD;oBACE,QAAQ,EAAE,UAAU;oBACpB,KAAK,EAAE,CAAC,UAAU,CAAC;oBACnB,MAAM,EAAE,CAAC,WAAW,EAAE,YAAY,CAAC,EAAE,6BAA6B;iBACnE;gBACD;oBACE,QAAQ,EAAE,OAAO;oBACjB,MAAM,EAAE,CAAC,YAAY,CAAC;iBACvB;gBACD;oBACE,QAAQ,EAAE,WAAW;oBACrB,MAAM,EAAE,CAAC,YAAY,CAAC;iBACvB;gBACD;oBACE,QAAQ,EAAE,WAAW;oBACrB,MAAM,EAAE,CAAC,YAAY,CAAC;iBACvB;gBACD;oBACE,QAAQ,EAAE,eAAe;oBACzB,MAAM,EAAE,CAAC,YAAY,EAAE,YAAY,CAAC;iBACrC;aACF;YACD,oCAAoC,EAAE,OAAO;YAC7C,sCAAsC,EAAE;gBACtC,OAAO;gBACP,EAAE,gBAAgB,EAAE,EAAE,EAAE;aACzB;YACD,oDAAoD,EAAE,OAAO;YAC7D,iDAAiD,EAAE;gBACjD,OAAO;gBACP,EAAE,oBAAoB,EAAE,IAAI,EAAE;aAC/B;YACD,kCAAkC,EAAE,OAAO;YAC3C,6CAA6C,EAAE,OAAO;YACtD,mDAAmD,EAAE,OAAO;YAC5D,yCAAyC,EAAE,OAAO;YAClD,gDAAgD;YAChD,gDAAgD,EAAE,OAAO;YACzD,8IAA8I;YAC9I,yCAAyC,EAAE;gBACzC,OAAO;gBACP;oBACE,UAAU,EAAE,KAAK;iBAClB;aACF;YACD,oCAAoC,EAAE,OAAO;YAC7C,gDAAgD,EAAE,OAAO;YACzD,wCAAwC,EAAE,OAAO;YACjD,yCAAyC,EAAE,OAAO;YAClD,mCAAmC,EAAE,OAAO;YAC5C,wCAAwC,EAAE,OAAO;YACjD,sCAAsC,EAAE,OAAO;YAC/C,mCAAmC,EAAE,OAAO;YAC5C,iCAAiC,EAAE;gBACjC,OAAO;gBACP,EAAE,oBAAoB,EAAE,KAAK,EAAE;aAChC;YACD,4DAA4D,EAAE,OAAO;YACrE,wDAAwD,EAAE,OAAO;YACjE,0CAA0C,EAAE,OAAO;YACnD,mDAAmD,EAAE,OAAO;YAC5D,uCAAuC,EAAE,OAAO;YAChD,2DAA2D,EAAE,OAAO;YACpE,6CAA6C,EAAE;gBAC7C,OAAO;gBACP,2JAA2J;gBAC3J,EAAE,2BAA2B,EAAE,QAAQ,EAAE;aAC1C;YACD,iEAAiE,EAC/D,OAAO;YACT,uDAAuD,EAAE,OAAO,EAAE,yBAAyB;YAC3F,kDAAkD,EAAE,OAAO;YAC3D,kDAAkD,EAAE,OAAO;YAC3D,mDAAmD,EAAE,OAAO;YAC5D,mDAAmD,EAAE,OAAO;YAC5D,mCAAmC,EAAE,OAAO;YAC5C,kDAAkD,EAAE,OAAO;YAC3D,8CAA8C,EAAE,OAAO;YACvD,4CAA4C,EAAE,OAAO;YACrD,qCAAqC,EAAE,OAAO,EAAE,yGAAyG;YACzJ,0CAA0C,EAAE,OAAO;YACnD,kDAAkD,EAAE,OAAO;YAC3D,4CAA4C,EAAE,OAAO;YACrD,sDAAsD,EAAE,OAAO;YAC/D,qCAAqC,EAAE;gBACrC,OAAO;gBACP,EAAE,oBAAoB,EAAE,KAAK,EAAE;aAChC;YACD,oCAAoC,EAAE,OAAO;YAC7C,yCAAyC,EAAE,OAAO;YAClD,oCAAoC,EAAE,OAAO;YAC7C,+CAA+C,EAAE,OAAO;YACxD,6CAA6C,EAAE,OAAO;YACtD,8CAA8C,EAAE,OAAO;YACvD,0CAA0C,EAAE,OAAO;YACnD,oCAAoC,EAAE,OAAO;YAC7C,uCAAuC,EAAE,OAAO;YAChD,4CAA4C,EAAE,OAAO;YACrD,2CAA2C,EAAE,OAAO;YACpD,2CAA2C,EAAE;gBAC3C,OAAO;gBACP;oBACE,mBAAmB;oBACnB,YAAY,EAAE,KAAK;oBACnB,YAAY,EAAE,KAAK;oBACnB,oBAAoB,EAAE,KAAK;oBAC3B,WAAW,EAAE,KAAK;oBAClB,uBAAuB,EAAE,KAAK;iBAC/B;aACF;YACD,kDAAkD,EAAE;gBAClD,OAAO;gBACP;oBACE,KAAK,EAAE,EAAE;oBACT,mBAAmB;oBACnB,YAAY,EAAE,KAAK;oBACnB,UAAU,EAAE,KAAK;oBACjB,YAAY,EAAE,KAAK;oBACnB,sBAAsB;oBACtB,WAAW,EAAE,KAAK;iBACnB;aACF;YACD,gDAAgD,EAAE,OAAO;YACzD,iCAAiC,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC;YACtD,gDAAgD,EAAE;gBAChD,OAAO;gBACP,EAAE,yBAAyB,EAAE,IAAI,EAAE;aACpC;YACD,mCAAmC,EAAE,OAAO;YAC5C,uCAAuC,EAAE,OAAO;YAChD,2DAA2D,EAAE,OAAO;SACrE;KACO,CAAC;AACb,CAAC","sourcesContent":["import * as fengeTsPlugin from \"@fenge/eslint-plugin-ts\";\nimport { getJsBase } from \"../js/base.ts\";\n\nexport function getTsBase() {\n  const jsBase = getJsBase();\n\n  const getTsExtensionRules = () => {\n    // Key is js rule, value is ts rule\n    // https://typescript-eslint.io/rules/?=extension\n    // Some rules are implemented by eslint core, so we comment them out.\n    const extensionRuleMap = {\n      // \"class-methods-use-this\": \"@typescript-eslint/class-methods-use-this\", // 9.23.0\n      \"consistent-return\": \"@typescript-eslint/consistent-return\",\n      // \"default-param-last\": \"@typescript-eslint/default-param-last\", // 9.23.0\n      \"dot-notation\": \"@typescript-eslint/dot-notation\",\n      // \"init-declarations\": \"@typescript-eslint/init-declarations\", // 9.24.0\n      // \"max-params\": \"@typescript-eslint/max-params\", // 9.27.0\n      // \"no-array-constructor\": \"@typescript-eslint/no-array-constructor\", // 9.24.0\n      // \"no-dupe-class-members\": \"@typescript-eslint/no-dupe-class-members\", // 9.24.0\n      // \"no-empty-function\": \"@typescript-eslint/no-empty-function\", // 9.25.0\n      \"no-implied-eval\": \"@typescript-eslint/no-implied-eval\",\n      // \"no-invalid-this\": \"@typescript-eslint/no-invalid-this\", // 9.25.0\n      // \"no-loop-func\": \"@typescript-eslint/no-loop-func\", // 9.25.0\n      // \"no-loss-of-precision\": \"@typescript-eslint/no-loss-of-precision\", // 9.24.0. And this rule has been deprecated\n      // \"no-magic-numbers\": \"@typescript-eslint/no-magic-numbers\", // 9.28.0\n      \"no-redeclare\": \"@typescript-eslint/no-redeclare\",\n      \"no-restricted-imports\": \"@typescript-eslint/no-restricted-imports\",\n      // \"no-shadow\": \"@typescript-eslint/no-shadow\", // 9.28.0\n      // \"no-unused-expressions\": \"@typescript-eslint/no-unused-expressions\", // 9.25.0\n      \"no-unused-vars\": \"@typescript-eslint/no-unused-vars\",\n      // \"no-use-before-define\": \"@typescript-eslint/no-use-before-define\", // 9.28.0\n      // \"no-useless-constructor\": \"@typescript-eslint/no-useless-constructor\", // 9.23.0\n      \"no-throw-literal\": \"@typescript-eslint/only-throw-error\",\n      \"prefer-destructuring\": \"@typescript-eslint/prefer-destructuring\",\n      \"prefer-promise-reject-errors\":\n        \"@typescript-eslint/prefer-promise-reject-errors\",\n      \"require-await\": \"@typescript-eslint/require-await\",\n      \"no-return-await\": \"@typescript-eslint/return-await\", // no-return-await has been deprecated\n    } as const;\n\n    type Js2TsRuleMap = typeof extensionRuleMap;\n    type Ts2JsRuleMap = {\n      [K in keyof Js2TsRuleMap as Js2TsRuleMap[K]]: K; // reverse\n    };\n\n    type JsExtensionKey = Extract<\n      keyof Js2TsRuleMap,\n      keyof typeof jsBase.rules\n    >; // Extract\n    type TsExtensionKey = Js2TsRuleMap[JsExtensionKey];\n\n    type JsResult = Record<JsExtensionKey, \"off\">;\n    type TsResult = {\n      [Key in TsExtensionKey]: (typeof jsBase.rules)[Ts2JsRuleMap[Key]];\n    };\n    type Result = JsResult & TsResult;\n\n    const isInExtensionRuleMap = (\n      key: string,\n    ): key is keyof typeof extensionRuleMap => key in extensionRuleMap;\n    return Object.entries(jsBase.rules).reduce(\n      (result, [jsRuleKey, jsRuleValue]) =>\n        isInExtensionRuleMap(jsRuleKey)\n          ? {\n              ...result,\n              [jsRuleKey]: \"off\",\n              [extensionRuleMap[jsRuleKey]]: jsRuleValue,\n            }\n          : result,\n      {} as Result,\n    );\n  };\n\n  return {\n    ...jsBase,\n    name: \"fenge/typescript\",\n    files: [\"**/*.{ts,cts,mts,tsx}\"],\n    languageOptions: {\n      ...jsBase.languageOptions,\n      parserOptions: {\n        ...jsBase.languageOptions.parserOptions,\n        // Setting `projectService: true` or `project: true` is pretty slow when lint a monorepo with many tsconfig.json files in each sub-app.\n        // But setting `project: \"tsconfig.json\"` will cause parser error when the project root tsconfig.json is `{ extends: \"fenge/tsconfig\" }`\n        projectService: true,\n      },\n      globals: {\n        ...jsBase.languageOptions.globals,\n        NodeJS: false,\n      },\n    },\n    plugins: {\n      ...jsBase.plugins,\n      \"@fenge-ts\": fengeTsPlugin,\n    },\n    rules: {\n      ...jsBase.rules,\n      ...getTsExtensionRules(),\n\n      // fenge\n      \"@fenge-ts/exact-map-set-type\": \"error\",\n      \"@fenge-ts/no-const-enum\": \"error\",\n      \"@fenge-ts/no-declares\": \"error\",\n      \"@fenge-ts/no-export-assignment\": \"error\",\n      \"@fenge-ts/no-misuse-spreading-parameter\": \"error\",\n      \"@fenge-ts/no-property-decorator\": \"error\",\n      \"@fenge-ts/no-untyped-empty-array\": \"error\",\n      // typescript\n      \"@typescript-eslint/adjacent-overload-signatures\": \"error\",\n      // \"@typescript-eslint/array-type\": [\"error\", 'array-simple'], // The default option is 'array'. Not very sure if we need to change the option. So disabled it.\n      \"@typescript-eslint/await-thenable\": \"error\",\n      \"@typescript-eslint/class-literal-property-style\": \"error\",\n      \"@typescript-eslint/consistent-generic-constructors\": \"error\",\n      \"@typescript-eslint/consistent-indexed-object-style\": \"error\",\n      \"@typescript-eslint/consistent-type-assertions\": [\n        \"error\",\n        {\n          assertionStyle: \"as\",\n          objectLiteralTypeAssertions: \"allow-as-parameter\",\n        },\n      ],\n      \"@typescript-eslint/consistent-type-definitions\": [\"error\", \"interface\"], // TODO should we change to 'type'?\n      \"@typescript-eslint/consistent-type-exports\": \"error\",\n      \"@typescript-eslint/consistent-type-imports\": \"error\",\n      \"@typescript-eslint/dot-notation\": [\"error\", { allowKeywords: true }],\n      \"@typescript-eslint/method-signature-style\": \"error\",\n      \"@typescript-eslint/naming-convention\": [\n        \"error\",\n        {\n          selector: \"function\",\n          format: [\"camelCase\", \"PascalCase\"],\n        },\n        {\n          selector: \"variable\",\n          types: [\"function\"],\n          format: [\"camelCase\", \"PascalCase\"], // decorators need PascalCase\n        },\n        {\n          selector: \"class\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"interface\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"typeAlias\",\n          format: [\"PascalCase\"],\n        },\n        {\n          selector: \"typeParameter\",\n          format: [\"UPPER_CASE\", \"PascalCase\"],\n        },\n      ],\n      \"@typescript-eslint/no-array-delete\": \"error\",\n      \"@typescript-eslint/no-base-to-string\": [\n        \"error\",\n        { ignoredTypeNames: [] },\n      ],\n      \"@typescript-eslint/no-confusing-non-null-assertion\": \"error\",\n      \"@typescript-eslint/no-confusing-void-expression\": [\n        \"error\",\n        { ignoreArrowShorthand: true },\n      ],\n      \"@typescript-eslint/no-deprecated\": \"error\",\n      \"@typescript-eslint/no-duplicate-enum-values\": \"error\",\n      \"@typescript-eslint/no-duplicate-type-constituents\": \"error\",\n      \"@typescript-eslint/no-empty-object-type\": \"error\",\n      // \"@typescript-eslint/no-explicit-any\": \"warn\",\n      \"@typescript-eslint/no-extra-non-null-assertion\": \"error\",\n      // \"@typescript-eslint/no-extraneous-class\": \"error\", // Classes have only static member is reasonable sometimes. Nestjs modules use it a lot.\n      \"@typescript-eslint/no-floating-promises\": [\n        \"error\",\n        {\n          ignoreVoid: false,\n        },\n      ],\n      \"@typescript-eslint/no-for-in-array\": \"error\",\n      \"@typescript-eslint/no-import-type-side-effects\": \"error\",\n      \"@typescript-eslint/no-inferrable-types\": \"error\",\n      \"@typescript-eslint/no-invalid-void-type\": \"error\",\n      \"@typescript-eslint/no-misused-new\": \"error\",\n      \"@typescript-eslint/no-misused-promises\": \"error\",\n      \"@typescript-eslint/no-misused-spread\": \"error\",\n      \"@typescript-eslint/no-mixed-enums\": \"error\",\n      \"@typescript-eslint/no-namespace\": [\n        \"error\",\n        { allowDefinitionFiles: false },\n      ],\n      \"@typescript-eslint/no-non-null-asserted-nullish-coalescing\": \"error\",\n      \"@typescript-eslint/no-non-null-asserted-optional-chain\": \"error\",\n      \"@typescript-eslint/no-non-null-assertion\": \"error\",\n      \"@typescript-eslint/no-redundant-type-constituents\": \"error\",\n      \"@typescript-eslint/no-require-imports\": \"error\",\n      \"@typescript-eslint/no-unnecessary-boolean-literal-compare\": \"error\",\n      \"@typescript-eslint/no-unnecessary-condition\": [\n        \"error\",\n        // TODO: If https://github.com/typescript-eslint/typescript-eslint/issues/11978 is fixed, change to `allowConstantLoopConditions: \"only-allowed-literals\"`.\n        { allowConstantLoopConditions: \"always\" },\n      ],\n      \"@typescript-eslint/no-unnecessary-parameter-property-assignment\":\n        \"error\",\n      \"@typescript-eslint/no-unnecessary-template-expression\": \"error\", // js also need this rule\n      \"@typescript-eslint/no-unnecessary-type-arguments\": \"error\",\n      \"@typescript-eslint/no-unnecessary-type-assertion\": \"error\",\n      \"@typescript-eslint/no-unnecessary-type-constraint\": \"error\",\n      \"@typescript-eslint/no-unnecessary-type-conversion\": \"error\",\n      \"@typescript-eslint/no-unsafe-call\": \"error\",\n      \"@typescript-eslint/no-unsafe-declaration-merging\": \"error\",\n      \"@typescript-eslint/no-unsafe-enum-comparison\": \"error\",\n      \"@typescript-eslint/no-unsafe-function-type\": \"error\",\n      \"@typescript-eslint/no-unsafe-return\": \"error\", // This rule is not very perfect. See https://github.com/typescript-eslint/typescript-eslint/issues/10439\n      \"@typescript-eslint/no-unsafe-unary-minus\": \"error\",\n      \"@typescript-eslint/no-useless-default-assignment\": \"error\",\n      \"@typescript-eslint/no-wrapper-object-types\": \"error\",\n      \"@typescript-eslint/non-nullable-type-assertion-style\": \"error\",\n      \"@typescript-eslint/only-throw-error\": [\n        \"error\",\n        { allowThrowingUnknown: false },\n      ],\n      \"@typescript-eslint/prefer-as-const\": \"error\",\n      \"@typescript-eslint/prefer-function-type\": \"error\",\n      \"@typescript-eslint/prefer-includes\": \"error\",\n      \"@typescript-eslint/prefer-literal-enum-member\": \"error\",\n      \"@typescript-eslint/prefer-namespace-keyword\": \"error\",\n      \"@typescript-eslint/prefer-nullish-coalescing\": \"error\",\n      \"@typescript-eslint/prefer-optional-chain\": \"error\",\n      \"@typescript-eslint/prefer-readonly\": \"error\",\n      \"@typescript-eslint/prefer-regexp-exec\": \"error\",\n      \"@typescript-eslint/prefer-return-this-type\": \"error\",\n      \"@typescript-eslint/promise-function-async\": \"error\",\n      \"@typescript-eslint/restrict-plus-operands\": [\n        \"error\",\n        {\n          // allowAny: false,\n          allowBoolean: false,\n          allowNullish: false,\n          allowNumberAndString: false,\n          allowRegExp: false,\n          skipCompoundAssignments: false,\n        },\n      ],\n      \"@typescript-eslint/restrict-template-expressions\": [\n        \"error\",\n        {\n          allow: [],\n          // allowAny: false,\n          allowBoolean: false,\n          allowNever: false,\n          allowNullish: false,\n          // allowNumber: false,\n          allowRegExp: false,\n        },\n      ],\n      \"@typescript-eslint/related-getter-setter-pairs\": \"error\",\n      \"@typescript-eslint/return-await\": [\"error\", \"always\"],\n      \"@typescript-eslint/switch-exhaustiveness-check\": [\n        \"error\",\n        { requireDefaultForNonUnion: true },\n      ],\n      \"@typescript-eslint/unbound-method\": \"error\",\n      \"@typescript-eslint/unified-signatures\": \"error\",\n      \"@typescript-eslint/use-unknown-in-catch-callback-variable\": \"error\",\n    },\n  } as const;\n}\n"]}