module Dialog.AddCategory.Model exposing ( Model , init , initialAdd , initialClone , initialEdit , validation ) import Date exposing (Date) import View.Date as Date import Form exposing (Form) import Form.Field as Field exposing (Field) import Form.Validate as Validate exposing (Validation) import Model.Translations exposing (Translations) import Model.Category exposing (Category, CategoryId) type alias Model = { id : Maybe CategoryId , name : String , color : String } init : Form String Model init = Form.initial [] validation initialAdd : Translations -> List (String, Field) initialAdd translations = [ ("color", Field.string "#000000") ] initialClone : Translations -> Category -> List (String, Field) initialClone translations category = [ ("name", Field.string category.name) , ("color", Field.string category.color) ] initialEdit : Translations -> CategoryId -> Category -> List (String, Field) initialEdit translations categoryId category = [ ("id", Field.string (toString categoryId)) , ("name", Field.string category.name) , ("color", Field.string category.color) ] validation : Validation String Model validation = Validate.map3 Model (Validate.field "id" (Validate.maybe Validate.int)) (Validate.field "name" (Validate.string |> Validate.andThen Validate.nonEmpty)) (Validate.field "color" (Validate.string |> Validate.andThen Validate.nonEmpty))