Skip to content

Commit

Permalink
Fix explicit boolean predicates rule not working with boolean constan…
Browse files Browse the repository at this point in the history
…ts (twentyhq#5009)

### Description
Fix explicit boolean predicates rule not working with boolean constants

### Refs
twentyhq#4881

### Demo

Fixes twentyhq#4881

Co-authored-by: gitstart-twenty <gitstart-twenty@users.noreply.github.com>
Co-authored-by: v1b3m <vibenjamin6@gmail.com>
Co-authored-by: Matheus <matheus_benini@hotmail.com>
  • Loading branch information
4 people authored Apr 17, 2024
1 parent 6cf3ade commit d54e690
Show file tree
Hide file tree
Showing 5 changed files with 7 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@ export const usePreviousHotkeyScope = () => {
return;
}

// eslint-disable-next-line @nx/workspace-explicit-boolean-predicates-in-if
if (DEBUG_HOTKEY_SCOPE) {
logDebug('DEBUG: goBackToPreviousHotkeyScope', previousHotkeyScope);
}
Expand All @@ -45,7 +44,6 @@ export const usePreviousHotkeyScope = () => {
.getLoadable(currentHotkeyScopeState)
.getValue();

// eslint-disable-next-line @nx/workspace-explicit-boolean-predicates-in-if
if (DEBUG_HOTKEY_SCOPE) {
logDebug('DEBUG: setHotkeyScopeAndMemorizePreviousScope', {
currentHotkeyScope,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@ export const useScopedHotkeyCallback = () =>
.getValue();

if (!currentHotkeyScopes.includes(scope)) {
// eslint-disable-next-line @nx/workspace-explicit-boolean-predicates-in-if
if (DEBUG_HOTKEY_SCOPE) {
logDebug(
`DEBUG: %cI can't call hotkey (${
Expand All @@ -43,7 +42,6 @@ export const useScopedHotkeyCallback = () =>
return;
}

// eslint-disable-next-line @nx/workspace-explicit-boolean-predicates-in-if
if (DEBUG_HOTKEY_SCOPE) {
logDebug(
`DEBUG: %cI can call hotkey (${
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -79,9 +79,6 @@ export const useSetHotkeyScope = () =>

scopesToSet.push(newHotkeyScope.scope);

// TODO: fix eslint rule not understanding a boolean constant
// See issue https://github.com/twentyhq/twenty/issues/4881
// eslint-disable-next-line @nx/workspace-explicit-boolean-predicates-in-if
if (DEBUG_HOTKEY_SCOPE) {
logDebug('DEBUG: set new hotkey scope', {
scopesToSet,
Expand Down
1 change: 0 additions & 1 deletion packages/twenty-front/src/utils/cast-as-integer-or-null.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
/* eslint-disable @nx/workspace-explicit-boolean-predicates-in-if */
import { isNull, isNumber, isString } from '@sniptt/guards';

import { logError } from './logError';
Expand Down
9 changes: 7 additions & 2 deletions tools/eslint-rules/rules/explicit-boolean-predicates-in-if.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,13 @@
import { ESLintUtils, TSESTree } from '@typescript-eslint/experimental-utils';
import ts from 'typescript';

export const RULE_NAME = 'explicit-boolean-predicates-in-if';

const isBooleanType = (type: ts.Type) => {
// check if boolean flag(s) is set on the type (e.g. boolean, true, false, etc.)
return type && (type.flags & ts.TypeFlags.BooleanLike) !== 0;
};

export const rule = ESLintUtils.RuleCreator(() => __filename)({
name: RULE_NAME,
meta: {
Expand All @@ -27,9 +33,8 @@ export const rule = ESLintUtils.RuleCreator(() => __filename)({
const tsNode = parserServices.esTreeNodeToTSNodeMap.get(node.test);
const type = typeChecker.getTypeAtLocation(tsNode);

if (typeChecker.typeToString(type) !== 'boolean') {
if (!isBooleanType(type)) {
const { test } = node;

context.report({
node: test,
messageId: 'nonExplicitPredicate',
Expand Down

0 comments on commit d54e690

Please sign in to comment.