houdini/client/js/nonprofits/button/designations.js
Bradley M. Kuhn fc77ee76d6 Relicense Javascript code in accordance with project's new license
The primary license of the project is changing to:
  AGPL-3.0-or-later WITH Web-Template-Output-Additional-Permission-3.0-or-later

The Additional Permission is designed to permit publicly distributed
Javascript code to be relicensed under LGPL-3.0-or-later, but not server-side
Javascript code.  As such, we've relicensed here static Javscript files under
LGPL-3.0-or-later, and those that run as part of build and/or server side
under AGPL-3.0-or-later.

Note that in future, Javascript files may be updated to be stronger copyleft
license with the Additional Permission, particularly if they adapted to run
on server side and/or turned into templates.  Of course, we'd seek public
discussion with the contributor community about such changes.

This commit is one of the many steps to relicense the entire codebase.

Documentation granting permission for this relicensing (from all past
contributors who hold copyrights) is on file with Software Freedom
Conservancy, Inc.
2018-03-25 15:10:40 -04:00

86 lines
2.8 KiB
JavaScript

// License: LGPL-3.0-or-later
var flyd = require("flyd")
var h = require("virtual-dom/h")
var footer = require('./footer')
var radioAndLabelWrapper = require('../../components/radio-and-label-wrapper')
var nameStream = flyd.stream()
var countStream = flyd.stream()
var inputStream = flyd.stream()
flyd.map(function(keyup){
keyup.target.value = keyup.target.value.replace(/[&"_*`'~]/g, "")
}, inputStream)
var namePrefix = 'settings.designations.'
module.exports = {
root: root,
streams: {
name: flyd.merge(nameStream, inputStream),
count: countStream
}
}
function root(state) {
return [
h('header.step-header', h('h4.step-title', 'Designations')),
h('div.step-inner',
[
body(state),
footer.root('Next', 'amounts')
])
]
}
function body(state){
var desigs = state.settings.designations
return [menu(),
input(desigs),
inputs(desigs)]
}
function menu(){
return h('aside',[
radioAndLabelWrapper('radio-no-designations', namePrefix + 'name', {'checked': 'checked', 'value': ''},
["I want ", h('strong', 'no'), " designation."], nameStream),
radioAndLabelWrapper('radio-single-designations', namePrefix + 'name', {'value': 'single'},
["I want a ", h('strong', 'single, preset'), " designation."], nameStream),
radioAndLabelWrapper('radio-multiple-designations', namePrefix + 'name', {'value': 'multiple'},
["I want donors to be able to select from ", h('strong', 'multiple'), " designations (up to 20)."], nameStream),
])
}
function input(desigs){
return h('input.u-marginTop--15.input--400',
{placeholder: 'Designation name', attributes: {'maxlength': 50}, name: namePrefix + 'single', style: {display: desigs.name === 'single' ? 'block' : 'none'},
onchange: inputStream
}
)
}
function inputs(desigs){
var prompt = [h('p.pastelBox--green.u-padding--10.u-marginY--10', 'If you would like to add a custom prompt to your donors, \
please enter it below. Example: "Which radio show would you like to donate to?". The default prompt is "Please select a designation".'),
h('input.u-marginTop--10.input--400',
{placeholder: 'Prompt to donors', attributes: {'maxlength': 50}, name: namePrefix + 'prompt', onkeyup: inputStream})
]
var inputs = []
for(var i = 0; i < desigs.count; i++) {
inputs.push(h('li', h('input.input--400', {attributes: {'maxlength': 50}, placeholder: 'Designation name', name: namePrefix + 'multiples.' + i, onchange: inputStream})))
}
return h('div', {style: {display: desigs.name === 'multiple' ? 'block' : 'none'}}, [
prompt,
h('p.pastelBox--blue.u-padding--10.u-marginY--10', 'Enter your designations below.'),
h('ol', [
inputs,
h('a.button--tiny.edit', {onclick: countStream, attributes: isDisabled(desigs.count)}, [h('i.fa.fa-plus'), ' Add another designation']),
])
])
}
function isDisabled(count){ if(count >= 20){return {'disabled' : ''}}}