forked from Emi/ELOS-License-Builder
Added the new license chooser!
This commit is contained in:
parent
41af1105e9
commit
0e45ebb40d
10
site/assets/cool-border.svg
Normal file
10
site/assets/cool-border.svg
Normal file
|
@ -0,0 +1,10 @@
|
|||
<svg width="180" height="180" version="1.1" viewBox="0 0 47.625 47.625" xmlns="http://www.w3.org/2000/svg">
|
||||
<g fill="none">
|
||||
<path d="m0.79883 12.306 11.507-11.507h23.014s11.507 0 11.507 11.507v23.014l-11.507 11.507c-11.507 0-23.014 0-34.52-2e-6l1.5e-7 -34.52" stroke="#ce027c" stroke-width=".79375"/>
|
||||
<g stroke="#9606b2">
|
||||
<path d="m2.4907 45.134h24.404" stroke-width=".79375"/>
|
||||
<path d="m41.24 38.498 4.0681-4.0681v-16.259" stroke-width=".79375"/>
|
||||
<path d="m2.4907 18.044v-5.0229l10.704-10.704h9.1849" stroke-width=".79375"/>
|
||||
</g>
|
||||
</g>
|
||||
</svg>
|
After Width: | Height: | Size: 560 B |
|
@ -83,6 +83,12 @@ header {
|
|||
border-top: 0;
|
||||
& ~ :not(.bevel) {
|
||||
background-color: var(--bevel);
|
||||
:first-child {
|
||||
margin-top: 0;
|
||||
}
|
||||
:last-child {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
&.bl, &.br {
|
||||
|
@ -96,6 +102,57 @@ header {
|
|||
}
|
||||
}
|
||||
|
||||
#license-chooser {
|
||||
margin: 0 -50px;
|
||||
#selected-license {
|
||||
border: 60px solid;
|
||||
border-image: url("/assets/cool-border.svg") 60;
|
||||
padding: 30px;
|
||||
border-radius: 20px;
|
||||
white-space: pre-wrap;
|
||||
h2 {
|
||||
margin-top: 0;
|
||||
}
|
||||
p {
|
||||
margin-bottom: 0;
|
||||
font-size: 1.3rem;
|
||||
line-height: 130%;
|
||||
}
|
||||
}
|
||||
#available-licenses {
|
||||
display: grid;
|
||||
grid-template-columns: repeat(2, 1fr);
|
||||
gap: 20px;
|
||||
margin-top: 20px;
|
||||
margin-bottom: 100px;
|
||||
|
||||
.selectable-license {
|
||||
background: none;
|
||||
border: 3px solid var(--color-hi);
|
||||
height: 50px;
|
||||
color: white;
|
||||
font-family: Lack, sansserif;
|
||||
font-size: 1.2rem;
|
||||
transform: skew(-15deg);
|
||||
cursor: pointer;
|
||||
|
||||
span {
|
||||
transform: skew(15deg);
|
||||
display: block;
|
||||
}
|
||||
|
||||
&:hover {
|
||||
background-color: #1f0430;
|
||||
}
|
||||
|
||||
&.active {
|
||||
background-color: var(--color-hi);
|
||||
color: var(--color-bg);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#modules {
|
||||
display: grid;
|
||||
grid-template-columns: 50% 50%;
|
||||
|
|
|
@ -7,6 +7,7 @@ module License exposing
|
|||
, downloadMime
|
||||
, empty
|
||||
, License
|
||||
, LicenseDescriptors
|
||||
, LicenseInfo
|
||||
, Template
|
||||
, ModuleInfo
|
||||
|
@ -82,6 +83,13 @@ type alias LicenseInfo modtype =
|
|||
{ availableModules : List modtype
|
||||
, templates : DownloadType -> Template modtype
|
||||
, moduleInfo : modtype -> ModuleInfo
|
||||
, descriptors : LicenseDescriptors
|
||||
}
|
||||
|
||||
type alias LicenseDescriptors =
|
||||
{ name : String
|
||||
, desc : String
|
||||
, slug : String
|
||||
}
|
||||
|
||||
empty : LicenseInfo modtype -> License modtype
|
||||
|
|
|
@ -17,6 +17,15 @@ info =
|
|||
{ availableModules = availableModules
|
||||
, templates = getTemplate
|
||||
, moduleInfo = moduleInfo
|
||||
, descriptors =
|
||||
{ name = "Hippocratic License 3.0"
|
||||
, slug = "HL"
|
||||
, desc = String.trim """
|
||||
The flagship ethical source license, the hippocratic license is one of the most customizable and practical ELOS licenses out there. The 3rd version features many optional modules to tailor the license to issues that matter to you, including optional copyleft functionality.
|
||||
|
||||
Also featured is an out-of-court arbitration clause, and restrictions that prevent any organizations involved in unethical practices from using the software, as opposed to just preventing the direct use of the software for unethical practices.
|
||||
"""
|
||||
}
|
||||
}
|
||||
|
||||
type Module
|
||||
|
|
|
@ -15,6 +15,17 @@ info =
|
|||
{ availableModules = availableModules
|
||||
, templates = getTemplate
|
||||
, moduleInfo = moduleInfo
|
||||
, descriptors =
|
||||
{ name = "Nonviolent Public License v7"
|
||||
, slug = "NVPL/CNPL"
|
||||
, desc = String.trim """
|
||||
The NVPL is perhaps best known for its variant the CNPL (Cooperative Nonviolent Public License), an ELOS license unique in its restriction of comercial use of software to worker owned co-operatives (check off "Worker Ownership" to enable this variant).
|
||||
|
||||
Even on its own, however, the NVPL is a powerful license, including protections against using the work to hurt others or using the work for surveilence, war/war-profiteering, incarceration, fossil fuel extraction/processing, child labor, and the spreading of hate speach.
|
||||
|
||||
The NVPL is also one of a few ELOS licenses that explicitly includes an (AGPL-like) clause that requires network services to distribute or link to the project's source code.
|
||||
"""
|
||||
}
|
||||
}
|
||||
|
||||
type Module
|
||||
|
|
47
src/Main.elm
47
src/Main.elm
|
@ -2,7 +2,7 @@ module Main exposing (main)
|
|||
|
||||
import Browser
|
||||
import Sort.Set as Set exposing (Set)
|
||||
import Html exposing (Html, div, input, label, p, section, text, h3)
|
||||
import Html exposing (Html, button, div, h2, input, label, p, section, text, span, h3)
|
||||
import Html.Events exposing (onCheck, onClick)
|
||||
import Html.Attributes exposing (class, type_, id)
|
||||
import Html.Attributes exposing (attribute)
|
||||
|
@ -28,6 +28,8 @@ subscriptions _ = Sub.none
|
|||
type SelectedLicense
|
||||
= Hippocratic
|
||||
| NPL
|
||||
availableLicenses : List SelectedLicense
|
||||
availableLicenses = [ Hippocratic, NPL ]
|
||||
|
||||
type alias Model =
|
||||
{ selected : SelectedLicense
|
||||
|
@ -35,6 +37,12 @@ type alias Model =
|
|||
, npl : License NPL.Module
|
||||
}
|
||||
|
||||
selectedInfo : SelectedLicense -> License.LicenseDescriptors
|
||||
selectedInfo selected =
|
||||
case selected of
|
||||
Hippocratic -> Hippocratic.info.descriptors
|
||||
NPL -> NPL.info.descriptors
|
||||
|
||||
init : () -> (Model, Cmd Msg)
|
||||
init () =
|
||||
(
|
||||
|
@ -100,6 +108,40 @@ view_module_button wrapModule moduleInfo enabled mod =
|
|||
]
|
||||
]
|
||||
|
||||
viewLicenseChooser : SelectedLicense -> Html Msg
|
||||
viewLicenseChooser selected =
|
||||
div
|
||||
[ id "license-chooser" ]
|
||||
[ selected
|
||||
|> selectedInfo
|
||||
|> viewLicenseInfo
|
||||
|> Html.map never
|
||||
, div [ id "available-licenses" ]
|
||||
( availableLicenses
|
||||
|> List.map (selectableLicense selected)
|
||||
)
|
||||
]
|
||||
|
||||
viewLicenseInfo : License.LicenseDescriptors -> Html Never
|
||||
viewLicenseInfo info =
|
||||
div [ id "selected-license" ]
|
||||
[ h2 [] [text info.name]
|
||||
, p [] [text info.desc]
|
||||
]
|
||||
|
||||
selectableLicense : SelectedLicense -> SelectedLicense -> Html Msg
|
||||
selectableLicense currentlySelected license =
|
||||
button
|
||||
( [ onClick (SwitchLicense license)
|
||||
, class "selectable-license"
|
||||
]
|
||||
++ if currentlySelected == license then [class "active"] else []
|
||||
)
|
||||
[ span []
|
||||
[ text (.slug (selectedInfo license))
|
||||
]
|
||||
]
|
||||
|
||||
view_modules : ModuleWrapper moduleType -> License moduleType -> Html Msg
|
||||
view_modules wrap license =
|
||||
section [id "modules"] (
|
||||
|
@ -144,7 +186,8 @@ downloads =
|
|||
view : Model -> Html Msg
|
||||
view model =
|
||||
div [id "elm-area"]
|
||||
[ case model.selected of
|
||||
[ viewLicenseChooser model.selected
|
||||
, case model.selected of
|
||||
Hippocratic -> view_modules HippocraticMod model.hippocratic
|
||||
NPL -> view_modules NPLMod model.npl
|
||||
, downloads
|
||||
|
|
Loading…
Reference in a new issue