mirror of
https://github.com/Orasund/elm-ui-widgets.git
synced 2024-11-22 22:33:33 +03:00
collecting all styles into one type
This commit is contained in:
parent
27dff31fb9
commit
be011f7acc
@ -27,6 +27,7 @@ import Widget.FilterMultiSelect as FilterMultiSelect
|
|||||||
import Widget.ScrollingNav as ScrollingNav
|
import Widget.ScrollingNav as ScrollingNav
|
||||||
import Widget.Snackbar as Snackbar
|
import Widget.Snackbar as Snackbar
|
||||||
import Widget.ValidatedInput as ValidatedInput
|
import Widget.ValidatedInput as ValidatedInput
|
||||||
|
import Data.Style exposing (style)
|
||||||
|
|
||||||
type alias Model =
|
type alias Model =
|
||||||
{ filterSelect : FilterSelect.Model
|
{ filterSelect : FilterSelect.Model
|
||||||
@ -40,13 +41,7 @@ type Msg
|
|||||||
| FilterMultiSelectSpecific FilterMultiSelect.Msg
|
| FilterMultiSelectSpecific FilterMultiSelect.Msg
|
||||||
| ValidatedInputSpecific ValidatedInput.Msg
|
| ValidatedInputSpecific ValidatedInput.Msg
|
||||||
|
|
||||||
chipButton : ButtonStyle msg
|
|
||||||
chipButton =
|
|
||||||
{ container = Tag.simple
|
|
||||||
, disabled = []
|
|
||||||
, label = Grid.simple
|
|
||||||
, active = Color.primary
|
|
||||||
}
|
|
||||||
|
|
||||||
init : Model
|
init : Model
|
||||||
init =
|
init =
|
||||||
@ -183,24 +178,7 @@ filterMultiSelect model =
|
|||||||
, icon = Element.none
|
, icon = Element.none
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|> Widget.textInput
|
|> Widget.textInput style.textInput
|
||||||
{ chip = chipButton
|
|
||||||
, chipsRow =
|
|
||||||
[ Element.width <| Element.shrink
|
|
||||||
, Element.spacing <| 4 ]
|
|
||||||
, containerRow =
|
|
||||||
Button.simple
|
|
||||||
++ Color.light
|
|
||||||
++ [ Border.color <| Element.rgb255 186 189 182
|
|
||||||
, Font.alignLeft
|
|
||||||
, Element.padding 8
|
|
||||||
, Element.height <| Element.px <|42
|
|
||||||
]
|
|
||||||
++ Grid.simple
|
|
||||||
, input =
|
|
||||||
Color.light
|
|
||||||
++ [Element.padding 0]
|
|
||||||
}
|
|
||||||
|
|
||||||
, model
|
, model
|
||||||
|> FilterMultiSelect.viewOptions
|
|> FilterMultiSelect.viewOptions
|
||||||
|
222
example/src/Data/Style.elm
Normal file
222
example/src/Data/Style.elm
Normal file
@ -0,0 +1,222 @@
|
|||||||
|
module Data.Style exposing (style)
|
||||||
|
|
||||||
|
import Widget exposing (TextInputStyle)
|
||||||
|
import Widget.Button exposing (ButtonStyle)
|
||||||
|
import Style exposing (Style)
|
||||||
|
import Element exposing (Attribute)
|
||||||
|
import Element.Input as Input
|
||||||
|
import Element.Font as Font
|
||||||
|
import Element.Border as Border
|
||||||
|
import Framework
|
||||||
|
import Framework.Button as Button
|
||||||
|
import Framework.Card as Card
|
||||||
|
import Framework.Color as Color
|
||||||
|
import Framework.Grid as Grid
|
||||||
|
import Framework.Group as Group
|
||||||
|
import Framework.Heading as Heading
|
||||||
|
import Framework.Input as Input
|
||||||
|
import Framework.Tag as Tag
|
||||||
|
import Icons
|
||||||
|
|
||||||
|
textButton : ButtonStyle msg
|
||||||
|
textButton =
|
||||||
|
{ container = Button.simple
|
||||||
|
, label = Grid.simple
|
||||||
|
, disabled = Color.disabled
|
||||||
|
, active = Color.primary
|
||||||
|
}
|
||||||
|
|
||||||
|
simpleButton : ButtonStyle msg
|
||||||
|
simpleButton =
|
||||||
|
{ container = Button.simple ++ Color.primary
|
||||||
|
, label = Grid.simple
|
||||||
|
, disabled = Color.disabled
|
||||||
|
, active = Color.primary
|
||||||
|
}
|
||||||
|
|
||||||
|
buttonStyle : ButtonStyle msg
|
||||||
|
buttonStyle =
|
||||||
|
{ label = [ Element.spacing 8]
|
||||||
|
, container = Button.simple
|
||||||
|
, disabled = Color.disabled
|
||||||
|
, active = Color.primary
|
||||||
|
}
|
||||||
|
|
||||||
|
tabButtonStyle :ButtonStyle msg
|
||||||
|
tabButtonStyle=
|
||||||
|
{ label = [ Element.spacing 8]
|
||||||
|
, container = Button.simple ++ Group.top
|
||||||
|
, disabled = Color.disabled
|
||||||
|
, active = Color.primary
|
||||||
|
}
|
||||||
|
|
||||||
|
textInputStyle =
|
||||||
|
{ chip = chipButtonStyle
|
||||||
|
, chipsRow =
|
||||||
|
[ Element.width <| Element.shrink
|
||||||
|
, Element.spacing <| 4
|
||||||
|
, Element.paddingEach
|
||||||
|
{ top = 8
|
||||||
|
, left = 0
|
||||||
|
, right = 0
|
||||||
|
, bottom = 8
|
||||||
|
}
|
||||||
|
]
|
||||||
|
, containerRow =
|
||||||
|
Button.simple
|
||||||
|
++ Color.light
|
||||||
|
++ [ Border.color <| Element.rgb255 186 189 182
|
||||||
|
, Font.alignLeft
|
||||||
|
, Element.paddingXY 8 0
|
||||||
|
, Element.height <| Element.px <|42
|
||||||
|
]
|
||||||
|
++ Grid.simple
|
||||||
|
, input =
|
||||||
|
Color.light
|
||||||
|
++ [ Element.padding 8
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
chipButtonStyle : ButtonStyle msg
|
||||||
|
chipButtonStyle =
|
||||||
|
{ container = Tag.simple
|
||||||
|
, disabled = []
|
||||||
|
, label = Grid.simple
|
||||||
|
, active = Color.primary
|
||||||
|
}
|
||||||
|
|
||||||
|
style : Style
|
||||||
|
{ dialog :
|
||||||
|
{ containerColumn : List (Attribute msg)
|
||||||
|
, title : List (Attribute msg)
|
||||||
|
, buttonRow : List (Attribute msg)
|
||||||
|
, accept : ButtonStyle msg
|
||||||
|
, dismiss : ButtonStyle msg
|
||||||
|
}
|
||||||
|
, button : ButtonStyle msg
|
||||||
|
, tabButton : ButtonStyle msg
|
||||||
|
, textInput : TextInputStyle msg
|
||||||
|
, chipButton : ButtonStyle msg
|
||||||
|
} msg
|
||||||
|
style =
|
||||||
|
{ button = buttonStyle
|
||||||
|
, tabButton = tabButtonStyle
|
||||||
|
, textInput = textInputStyle
|
||||||
|
, chipButton = chipButtonStyle
|
||||||
|
, dialog =
|
||||||
|
{ containerColumn =
|
||||||
|
Card.simple
|
||||||
|
++ Grid.simple
|
||||||
|
++ [ Element.width <| Element.minimum 280 <| Element.maximum 560 <| Element.fill ]
|
||||||
|
, title = Heading.h3
|
||||||
|
, buttonRow =
|
||||||
|
Grid.simple ++
|
||||||
|
[ Element.paddingEach
|
||||||
|
{ top = 28
|
||||||
|
, bottom = 0
|
||||||
|
, left = 0
|
||||||
|
, right = 0
|
||||||
|
}
|
||||||
|
]
|
||||||
|
, accept = simpleButton
|
||||||
|
, dismiss = textButton
|
||||||
|
}
|
||||||
|
, snackbar =
|
||||||
|
{ row =
|
||||||
|
Card.simple
|
||||||
|
++ Color.dark
|
||||||
|
++ Grid.simple
|
||||||
|
++ [ Element.paddingXY 8 6
|
||||||
|
, Element.height <| Element.px <|54]
|
||||||
|
, button =
|
||||||
|
{ label = Grid.simple
|
||||||
|
, container = Button.simple ++ Color.dark
|
||||||
|
, disabled = Color.disabled
|
||||||
|
, active = Color.primary
|
||||||
|
}
|
||||||
|
, text = [Element.paddingXY 8 0]
|
||||||
|
}
|
||||||
|
, layout = Framework.responsiveLayout
|
||||||
|
{--\a w ->
|
||||||
|
Html.div []
|
||||||
|
[ Html.node "meta"
|
||||||
|
[ Attributes.attribute "name" "viewport"
|
||||||
|
, Attributes.attribute "content" "width=device-width, initial-scale=1.0"
|
||||||
|
]
|
||||||
|
[]
|
||||||
|
, Element.layoutWith
|
||||||
|
{options = (Element.focusStyle
|
||||||
|
{ borderColor = Nothing
|
||||||
|
, backgroundColor = Nothing
|
||||||
|
, shadow = Nothing
|
||||||
|
}
|
||||||
|
|> List.singleton)
|
||||||
|
}
|
||||||
|
(Framework.layoutAttributes ++ a) <| w
|
||||||
|
]--}
|
||||||
|
, header =
|
||||||
|
Framework.container
|
||||||
|
++ Color.dark
|
||||||
|
++ [ Element.padding <| 0
|
||||||
|
, Element.height <| Element.px <| 42
|
||||||
|
]
|
||||||
|
, menuButton =
|
||||||
|
{ label = Grid.simple
|
||||||
|
, container = Button.simple ++ Group.center ++ Color.dark
|
||||||
|
, disabled = Color.disabled
|
||||||
|
, active = Color.primary
|
||||||
|
}
|
||||||
|
, sheetButton =
|
||||||
|
{ container =
|
||||||
|
Button.fill
|
||||||
|
++ Group.center
|
||||||
|
++ Color.light
|
||||||
|
++ [Font.alignLeft]
|
||||||
|
, label = Grid.simple
|
||||||
|
, disabled = Color.disabled
|
||||||
|
, active = Color.primary
|
||||||
|
}
|
||||||
|
, menuTabButton =
|
||||||
|
{ container =
|
||||||
|
[ Element.height <| Element.px <| 42
|
||||||
|
, Border.widthEach
|
||||||
|
{ top = 0,
|
||||||
|
left = 0,
|
||||||
|
right = 0,
|
||||||
|
bottom = 4
|
||||||
|
}
|
||||||
|
, Element.paddingEach
|
||||||
|
{ top = 12
|
||||||
|
, left = 8
|
||||||
|
, right = 8
|
||||||
|
, bottom = 4
|
||||||
|
}
|
||||||
|
, Border.color Color.black
|
||||||
|
]
|
||||||
|
, label = Grid.simple
|
||||||
|
, disabled = Color.disabled
|
||||||
|
, active = [ Border.color Color.turquoise ]
|
||||||
|
}
|
||||||
|
, sheet =
|
||||||
|
Color.light ++ [ Element.width <| Element.maximum 256 <| Element.fill]
|
||||||
|
, menuIcon =
|
||||||
|
Icons.menu |> Element.html |> Element.el []
|
||||||
|
, moreVerticalIcon =
|
||||||
|
Icons.moreVertical |> Element.html |> Element.el []
|
||||||
|
, spacing = 8
|
||||||
|
, title = Heading.h2
|
||||||
|
, searchIcon =
|
||||||
|
Icons.search |> Element.html |> Element.el []
|
||||||
|
, search =
|
||||||
|
Color.simple ++
|
||||||
|
Card.large ++
|
||||||
|
[Font.color <| Element.rgb255 0 0 0
|
||||||
|
, Element.padding 6
|
||||||
|
, Element.centerY
|
||||||
|
, Element.alignRight
|
||||||
|
]
|
||||||
|
, searchFill =
|
||||||
|
Color.light
|
||||||
|
++ Group.center
|
||||||
|
}
|
@ -22,7 +22,7 @@ import Html exposing (Html)
|
|||||||
import Html.Attributes as Attributes
|
import Html.Attributes as Attributes
|
||||||
import Icons
|
import Icons
|
||||||
import Layout exposing (Part, Layout)
|
import Layout exposing (Part, Layout)
|
||||||
import Core.Style exposing (Style)
|
import Data.Style exposing (style)
|
||||||
import Reusable
|
import Reusable
|
||||||
import Set exposing (Set)
|
import Set exposing (Set)
|
||||||
import Stateless
|
import Stateless
|
||||||
@ -78,149 +78,6 @@ type Msg
|
|||||||
= LoadedSpecific LoadedMsg
|
= LoadedSpecific LoadedMsg
|
||||||
| GotViewport Viewport
|
| GotViewport Viewport
|
||||||
|
|
||||||
textButton : ButtonStyle msg
|
|
||||||
textButton =
|
|
||||||
{ container = Button.simple
|
|
||||||
, label = Grid.simple
|
|
||||||
, disabled = Color.disabled
|
|
||||||
, active = Color.primary
|
|
||||||
}
|
|
||||||
|
|
||||||
simpleButton : ButtonStyle msg
|
|
||||||
simpleButton =
|
|
||||||
{ container = Button.simple ++ Color.primary
|
|
||||||
, label = Grid.simple
|
|
||||||
, disabled = Color.disabled
|
|
||||||
, active = Color.primary
|
|
||||||
}
|
|
||||||
|
|
||||||
style : Style
|
|
||||||
{ dialog :
|
|
||||||
{ containerColumn : List (Attribute msg)
|
|
||||||
, title : List (Attribute msg)
|
|
||||||
, buttonRow : List (Attribute msg)
|
|
||||||
, accept : ButtonStyle msg
|
|
||||||
, dismiss : ButtonStyle msg
|
|
||||||
}
|
|
||||||
} msg
|
|
||||||
style =
|
|
||||||
{ dialog =
|
|
||||||
{ containerColumn =
|
|
||||||
Card.simple
|
|
||||||
++ Grid.simple
|
|
||||||
++ [ Element.width <| Element.minimum 280 <| Element.maximum 560 <| Element.fill ]
|
|
||||||
, title = Heading.h3
|
|
||||||
, buttonRow =
|
|
||||||
Grid.simple ++
|
|
||||||
[ Element.paddingEach
|
|
||||||
{ top = 28
|
|
||||||
, bottom = 0
|
|
||||||
, left = 0
|
|
||||||
, right = 0
|
|
||||||
}
|
|
||||||
]
|
|
||||||
, accept = simpleButton
|
|
||||||
, dismiss = textButton
|
|
||||||
}
|
|
||||||
, snackbar =
|
|
||||||
{ row =
|
|
||||||
Card.simple
|
|
||||||
++ Color.dark
|
|
||||||
++ Grid.simple
|
|
||||||
++ [ Element.paddingXY 8 6
|
|
||||||
, Element.height <| Element.px <|54]
|
|
||||||
, button =
|
|
||||||
{ label = Grid.simple
|
|
||||||
, container = Button.simple ++ Color.dark
|
|
||||||
, disabled = Color.disabled
|
|
||||||
, active = Color.primary
|
|
||||||
}
|
|
||||||
, text = [Element.paddingXY 8 0]
|
|
||||||
}
|
|
||||||
, layout = Framework.responsiveLayout
|
|
||||||
{--\a w ->
|
|
||||||
Html.div []
|
|
||||||
[ Html.node "meta"
|
|
||||||
[ Attributes.attribute "name" "viewport"
|
|
||||||
, Attributes.attribute "content" "width=device-width, initial-scale=1.0"
|
|
||||||
]
|
|
||||||
[]
|
|
||||||
, Element.layoutWith
|
|
||||||
{options = (Element.focusStyle
|
|
||||||
{ borderColor = Nothing
|
|
||||||
, backgroundColor = Nothing
|
|
||||||
, shadow = Nothing
|
|
||||||
}
|
|
||||||
|> List.singleton)
|
|
||||||
}
|
|
||||||
(Framework.layoutAttributes ++ a) <| w
|
|
||||||
]--}
|
|
||||||
, header =
|
|
||||||
Framework.container
|
|
||||||
++ Color.dark
|
|
||||||
++ [ Element.padding <| 0
|
|
||||||
, Element.height <| Element.px <| 42
|
|
||||||
]
|
|
||||||
, menuButton =
|
|
||||||
{ label = Grid.simple
|
|
||||||
, container = Button.simple ++ Group.center ++ Color.dark
|
|
||||||
, disabled = Color.disabled
|
|
||||||
, active = Color.primary
|
|
||||||
}
|
|
||||||
, sheetButton =
|
|
||||||
{ container =
|
|
||||||
Button.fill
|
|
||||||
++ Group.center
|
|
||||||
++ Color.light
|
|
||||||
++ [Font.alignLeft]
|
|
||||||
, label = Grid.simple
|
|
||||||
, disabled = Color.disabled
|
|
||||||
, active = Color.primary
|
|
||||||
}
|
|
||||||
, menuTabButton =
|
|
||||||
{ container =
|
|
||||||
[ Element.height <| Element.px <| 42
|
|
||||||
, Border.widthEach
|
|
||||||
{ top = 0,
|
|
||||||
left = 0,
|
|
||||||
right = 0,
|
|
||||||
bottom = 4
|
|
||||||
}
|
|
||||||
, Element.paddingEach
|
|
||||||
{ top = 12
|
|
||||||
, left = 8
|
|
||||||
, right = 8
|
|
||||||
, bottom = 4
|
|
||||||
}
|
|
||||||
, Border.color Color.black
|
|
||||||
]
|
|
||||||
, label = Grid.simple
|
|
||||||
, disabled = Color.disabled
|
|
||||||
, active = [ Border.color Color.turquoise ]
|
|
||||||
}
|
|
||||||
, sheet =
|
|
||||||
Color.light ++ [ Element.width <| Element.maximum 256 <| Element.fill]
|
|
||||||
, menuIcon =
|
|
||||||
Icons.menu |> Element.html |> Element.el []
|
|
||||||
, moreVerticalIcon =
|
|
||||||
Icons.moreVertical |> Element.html |> Element.el []
|
|
||||||
, spacing = 8
|
|
||||||
, title = Heading.h2
|
|
||||||
, searchIcon =
|
|
||||||
Icons.search |> Element.html |> Element.el []
|
|
||||||
, search =
|
|
||||||
Color.simple ++
|
|
||||||
Card.large ++
|
|
||||||
[Font.color <| Element.rgb255 0 0 0
|
|
||||||
, Element.padding 6
|
|
||||||
, Element.centerY
|
|
||||||
, Element.alignRight
|
|
||||||
]
|
|
||||||
, searchFill =
|
|
||||||
Color.light
|
|
||||||
++ Group.center
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
initialModel : Viewport -> ( LoadedModel, Cmd LoadedMsg )
|
initialModel : Viewport -> ( LoadedModel, Cmd LoadedMsg )
|
||||||
initialModel { viewport } =
|
initialModel { viewport } =
|
||||||
|
@ -22,30 +22,7 @@ import Layout exposing (Part(..))
|
|||||||
import Icons
|
import Icons
|
||||||
import Widget
|
import Widget
|
||||||
import Element.Font as Font
|
import Element.Font as Font
|
||||||
|
import Data.Style exposing (style)
|
||||||
buttonStyle : ButtonStyle msg
|
|
||||||
buttonStyle =
|
|
||||||
{ label = [ Element.spacing 8]
|
|
||||||
, container = Button.simple
|
|
||||||
, disabled = Color.disabled
|
|
||||||
, active = Color.primary
|
|
||||||
}
|
|
||||||
|
|
||||||
tabButtonStyle :ButtonStyle msg
|
|
||||||
tabButtonStyle=
|
|
||||||
{ label = [ Element.spacing 8]
|
|
||||||
, container = Button.simple ++ Group.top
|
|
||||||
, disabled = Color.disabled
|
|
||||||
, active = Color.primary
|
|
||||||
}
|
|
||||||
|
|
||||||
chipButton : ButtonStyle msg
|
|
||||||
chipButton =
|
|
||||||
{ container = Tag.simple
|
|
||||||
, disabled = []
|
|
||||||
, label = Grid.simple
|
|
||||||
, active = Color.primary
|
|
||||||
}
|
|
||||||
|
|
||||||
type alias Model =
|
type alias Model =
|
||||||
{ selected : Maybe Int
|
{ selected : Maybe Int
|
||||||
@ -153,6 +130,9 @@ update msg model =
|
|||||||
|
|
||||||
select : Model -> (String,Element Msg)
|
select : Model -> (String,Element Msg)
|
||||||
select model =
|
select model =
|
||||||
|
let
|
||||||
|
buttonStyle = style.button
|
||||||
|
in
|
||||||
( "Select"
|
( "Select"
|
||||||
, { selected = model.selected
|
, { selected = model.selected
|
||||||
, options =
|
, options =
|
||||||
@ -188,6 +168,9 @@ select model =
|
|||||||
|
|
||||||
multiSelect : Model -> (String,Element Msg)
|
multiSelect : Model -> (String,Element Msg)
|
||||||
multiSelect model =
|
multiSelect model =
|
||||||
|
let
|
||||||
|
buttonStyle = style.button
|
||||||
|
in
|
||||||
( "Multi Select"
|
( "Multi Select"
|
||||||
, { selected = model.multiSelected
|
, { selected = model.multiSelected
|
||||||
, options =
|
, options =
|
||||||
@ -247,7 +230,7 @@ tab : Model -> (String,Element Msg)
|
|||||||
tab model =
|
tab model =
|
||||||
( "Tab"
|
( "Tab"
|
||||||
, Widget.tab
|
, Widget.tab
|
||||||
{ button = tabButtonStyle
|
{ button = style.tabButton
|
||||||
, optionRow = Grid.simple
|
, optionRow = Grid.simple
|
||||||
, containerColumn = Grid.compact
|
, containerColumn = Grid.compact
|
||||||
}
|
}
|
||||||
@ -339,7 +322,7 @@ carousel model =
|
|||||||
iconButton : Model -> (String,Element Msg)
|
iconButton : Model -> (String,Element Msg)
|
||||||
iconButton model =
|
iconButton model =
|
||||||
( "Icon Button"
|
( "Icon Button"
|
||||||
, [Button.view buttonStyle
|
, [Button.view style.button
|
||||||
{ text = "disable me"
|
{ text = "disable me"
|
||||||
, icon = Icons.slash |> Element.html |> Element.el [] , onPress =
|
, icon = Icons.slash |> Element.html |> Element.el [] , onPress =
|
||||||
if model.button then
|
if model.button then
|
||||||
@ -347,7 +330,7 @@ iconButton model =
|
|||||||
else
|
else
|
||||||
Nothing
|
Nothing
|
||||||
}
|
}
|
||||||
, Button.view buttonStyle
|
, Button.view style.button
|
||||||
{ text = "reset button"
|
{ text = "reset button"
|
||||||
, icon = Element.none
|
, icon = Element.none
|
||||||
, onPress = Just <| ToggleButton True
|
, onPress = Just <| ToggleButton True
|
||||||
@ -375,24 +358,7 @@ textInput model =
|
|||||||
, label = "Chips"
|
, label = "Chips"
|
||||||
, onChange = SetTextInput
|
, onChange = SetTextInput
|
||||||
}
|
}
|
||||||
|> Widget.textInput
|
|> Widget.textInput style.textInput
|
||||||
{ chip = chipButton
|
|
||||||
, chipsRow =
|
|
||||||
[ Element.width <| Element.shrink
|
|
||||||
, Element.spacing <| 4 ]
|
|
||||||
, containerRow =
|
|
||||||
Button.simple
|
|
||||||
++ Color.light
|
|
||||||
++ [ Border.color <| Element.rgb255 186 189 182
|
|
||||||
, Font.alignLeft
|
|
||||||
, Element.padding 8
|
|
||||||
, Element.height <| Element.px <|42
|
|
||||||
]
|
|
||||||
++ Grid.simple
|
|
||||||
, input =
|
|
||||||
Color.light
|
|
||||||
++ [Element.padding 0]
|
|
||||||
}
|
|
||||||
, model.chipTextInput
|
, model.chipTextInput
|
||||||
|> Set.diff
|
|> Set.diff
|
||||||
(["A","B","C"]
|
(["A","B","C"]
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
module Layout exposing (Layout, Part(..), activate, init, queueMessage, timePassed, view)
|
module Layout exposing (Layout, Part(..), activate, init, queueMessage, timePassed, view)
|
||||||
|
|
||||||
import Array
|
import Array
|
||||||
import Core.Style as Style exposing (Style)
|
|
||||||
import Element exposing (Attribute, DeviceClass(..), Element)
|
import Element exposing (Attribute, DeviceClass(..), Element)
|
||||||
import Element.Input as Input
|
import Element.Input as Input
|
||||||
import Html exposing (Html)
|
import Html exposing (Html)
|
||||||
|
import Style exposing (Style)
|
||||||
import Widget exposing (Select)
|
import Widget exposing (Select)
|
||||||
import Widget.Button as Button exposing (Button)
|
import Widget.Button as Button exposing (Button)
|
||||||
import Widget.Snackbar as Snackbar exposing (Message)
|
import Widget.Snackbar as Snackbar exposing (Message)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
module Core.Style exposing (Style, menuButton, menuIconButton, menuTabButton, sheetButton)
|
module Style exposing (Style, menuButton, menuIconButton, menuTabButton, sheetButton)
|
||||||
|
|
||||||
import Element exposing (Attribute, Element)
|
import Element exposing (Attribute, Element)
|
||||||
import Html exposing (Html)
|
import Html exposing (Html)
|
@ -1,6 +1,6 @@
|
|||||||
module Widget exposing
|
module Widget exposing
|
||||||
( select, multiSelect, collapsable, carousel, modal, tab, dialog
|
( select, multiSelect, collapsable, carousel, modal, tab, dialog
|
||||||
, Dialog, Select, selectButton, textInput
|
, Dialog, Select, TextInputStyle, selectButton, textInput
|
||||||
)
|
)
|
||||||
|
|
||||||
{-| This module contains functions for displaying data.
|
{-| This module contains functions for displaying data.
|
||||||
@ -37,6 +37,14 @@ type alias Dialog msg =
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
type alias TextInputStyle msg =
|
||||||
|
{ chip : ButtonStyle msg
|
||||||
|
, containerRow : List (Attribute msg)
|
||||||
|
, chipsRow : List (Attribute msg)
|
||||||
|
, input : List (Attribute msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
{-| A simple button
|
{-| A simple button
|
||||||
-}
|
-}
|
||||||
selectButton :
|
selectButton :
|
||||||
@ -103,11 +111,7 @@ multiSelect { selected, options, onSelect } =
|
|||||||
|
|
||||||
{-| -}
|
{-| -}
|
||||||
textInput :
|
textInput :
|
||||||
{ chip : ButtonStyle msg
|
TextInputStyle msg
|
||||||
, containerRow : List (Attribute msg)
|
|
||||||
, chipsRow : List (Attribute msg)
|
|
||||||
, input : List (Attribute msg)
|
|
||||||
}
|
|
||||||
->
|
->
|
||||||
{ chips : List (Button msg)
|
{ chips : List (Button msg)
|
||||||
, text : String
|
, text : String
|
||||||
|
Loading…
Reference in New Issue
Block a user