mirror of
https://github.com/jfmengels/elm-review.git
synced 2024-12-24 02:02:29 +03:00
61 lines
2.2 KiB
Elm
61 lines
2.2 KiB
Elm
module MiscRules.NoHtmlButton exposing (rule)
|
|
|
|
import Elm.Syntax.Expression exposing (Expression(..))
|
|
import Elm.Syntax.Node as Node exposing (Node)
|
|
import Review.ModuleNameLookupTable as ModuleNameLookupTable exposing (ModuleNameLookupTable)
|
|
import Review.Rule as Rule exposing (Error, Rule)
|
|
import Scope
|
|
|
|
|
|
rule : Rule
|
|
rule =
|
|
Rule.newModuleRuleSchemaUsingContextCreator "NoHtmlButton" contextCreator
|
|
-- Scope.addModuleVisitors should be added before your own visitors
|
|
--|> Scope.addModuleVisitors
|
|
|> Rule.withExpressionEnterVisitor expressionVisitor
|
|
|> Rule.fromModuleRuleSchema
|
|
|> Rule.ignoreErrorsForFiles [ "src/Button.elm" ]
|
|
|
|
|
|
type alias Context =
|
|
-- Scope expects a context with a record, containing the `scope` field.
|
|
{ scope : Scope.ModuleContext
|
|
, moduleNameLookupTable : ModuleNameLookupTable
|
|
}
|
|
|
|
|
|
contextCreator : Rule.ContextCreator () Context
|
|
contextCreator =
|
|
Rule.initContextCreator
|
|
(\moduleNameLookupTable () ->
|
|
{ scope = Scope.initialModuleContext
|
|
|
|
-- TODO FIND OUT WHY THINGS ARE NOT PASSED TO THE RULE
|
|
, moduleNameLookupTable = Debug.log "HTML button moduleNameLookupTable" moduleNameLookupTable
|
|
}
|
|
)
|
|
|> Rule.withModuleNameLookupTable
|
|
|
|
|
|
expressionVisitor : Node Expression -> Context -> ( List (Error {}), Context )
|
|
expressionVisitor node context =
|
|
case Node.value node of
|
|
FunctionOrValue _ "button" ->
|
|
if ModuleNameLookupTable.moduleNameFor context.moduleNameLookupTable node == Just [ "Html" ] then
|
|
-- TODO Remove
|
|
--if Scope.moduleNameForValue context.scope "button" moduleName == [ "Html" ] then
|
|
( [ Rule.error
|
|
{ message = "Do not use `Html.button` directly"
|
|
, details = [ "At fruits.com, we've built a nice `Button` module that suits our needs better. Using this module instead of `Html.button` ensures we have a consistent button experience across the website." ]
|
|
}
|
|
(Node.range node)
|
|
]
|
|
, context
|
|
)
|
|
|
|
else
|
|
( [], context )
|
|
|
|
_ ->
|
|
( [], context )
|