aboutsummaryrefslogtreecommitdiff
path: root/src/client/Validation.elm
diff options
context:
space:
mode:
authorJoris2020-01-30 11:35:31 +0000
committerJoris2020-01-30 11:35:31 +0000
commit960fa7cb7ae4c57d01306f78cd349f3a8337d0ab (patch)
tree5077cc720525fb025e4dba65a9a8b631862cbcc8 /src/client/Validation.elm
parent14bdbc8c937f5d0b35c61350dba28cb41c3737cd (diff)
parent6a04e640955051616c3ad0874605830c448f2d75 (diff)
Merge branch 'with-ghcjs' into 'master'
Use Haskell on the frontend See merge request guyonvarch/shared-cost!2
Diffstat (limited to 'src/client/Validation.elm')
-rw-r--r--src/client/Validation.elm65
1 files changed, 0 insertions, 65 deletions
diff --git a/src/client/Validation.elm b/src/client/Validation.elm
deleted file mode 100644
index de27963..0000000
--- a/src/client/Validation.elm
+++ /dev/null
@@ -1,65 +0,0 @@
-module Validation exposing
- ( cost
- , date
- , category
- , color
- , new
- )
-
-import Date exposing (Date)
-import Date.Extra.Core exposing (intToMonth)
-import Date.Extra.Create exposing (dateFromFields)
-import Dict
-import Regex
-import String exposing (toInt, split)
-
-import Form.Validate as Validate exposing (Validation)
-import Form.Error as Error exposing (ErrorValue(CustomError))
-
-import Model.Category exposing (Categories, CategoryId)
-
-cost : Validation String Int
-cost =
- Validate.customValidation Validate.int (\n ->
- if n == 0
- then Err (Validate.customError "CostMustNotBeNull")
- else Ok n
- )
-
-date : Validation String Date
-date =
- Validate.customValidation Validate.string (\str ->
- case split "/" str of
- [day, month, year] ->
- case (toInt day, toInt month, toInt year) of
- (Ok dayNum, Ok monthNum, Ok yearNum) ->
- Ok (dateFromFields yearNum (intToMonth monthNum) dayNum 0 0 0 0)
- _ -> Err (Validate.customError "InvalidDate")
- _ -> Err (Validate.customError "InvalidDate")
- )
-
-category : Categories -> Validation String CategoryId
-category categories =
- Validate.customValidation Validate.string (\str ->
- case toInt str of
- Ok category ->
- if List.member category (Dict.keys categories)
- then Ok category
- else Err (Validate.customError "InvalidCategory")
- Err _ ->
- Err (Validate.customError "InvalidCategory")
- )
-
-color : Validation String String
-color =
- Validate.customValidation Validate.string (\str ->
- if Regex.contains (Regex.regex "^#[0-9a-fA-F]{6}$") str
- then Ok str
- else Err (Validate.customError "InvalidColor")
- )
-
-new : List x -> x -> Validation String x
-new xs x field =
- if List.member x xs
- then Err (Error.value <| CustomError "AlreadyExists")
- else Ok x