bsw@1045: local return_to = param.get("return_to")
bsw/jbe@1309: local return_to_area_id = param.get("return_to_area_id", atom.integer)
bsw/jbe@1309: local return_to_area = Area:by_id(return_to_area_id)
bsw@1045: 
bsw@1126: ui.titleMember(_"notification settings")
bsw@286: 
bsw/jbe@1309: ui.grid{ content = function()
bsw/jbe@1309:   ui.cell_main{ content = function()
bsw/jbe@1309: 
bsw/jbe@1309:     ui.container{ attr = { class = "mdl-card mdl-card__fullwidth mdl-shadow--2dp" }, content = function()
bsw/jbe@1309:       ui.container{ attr = { class = "mdl-card__title mdl-card--border" }, content = function()
bsw/jbe@1309:         ui.heading { attr = { class = "mdl-card__title-text" }, level = 2, content = _"notification settings" }
bsw/jbe@1309:       end }
bsw/jbe@1309:       ui.container{ attr = { class = "mdl-card__content mdl-card--border" }, content = function()
bsw@286: 
bsw/jbe@1309:         ui.form{
bsw/jbe@1309:           attr = { class = "vertical" },
bsw/jbe@1309:           module = "member",
bsw/jbe@1309:           action = "update_notify_level",
bsw/jbe@1309:           routing = {
bsw/jbe@1309:             ok = {
bsw/jbe@1309:               mode = "redirect",
bsw/jbe@1309:               module = return_to == "area" and "index" or return_to == "home" and "index" or "member",
bsw/jbe@1309:               view = return_to == "area" and "index" or return_to == "home" and "index" or "settings",
bsw/jbe@1309:               params = return_to_area and { unit = return_to_area.unit_id, area = return_to_area.id } or nil
bsw@1045:             }
bsw/jbe@1309:           },
bsw/jbe@1309:           content = function()
bsw/jbe@1309: 
bsw/jbe@1309:           
bsw/jbe@1309:             ui.container{ content = function()
bsw/jbe@1309:               ui.tag{ tag = "label", attr = {
bsw/jbe@1309:                   class = "mdl-radio mdl-js-radio mdl-js-ripple-effect",
bsw/jbe@1309:                   ["for"] = "notify_level_all"
bsw/jbe@1309:                 },
bsw/jbe@1309:                 content = function()
bsw/jbe@1309:                   ui.tag{
bsw/jbe@1309:                     tag = "input",
bsw/jbe@1309:                     attr = {
bsw/jbe@1309:                       id = "notify_level_all",
bsw/jbe@1309:                       class = "mdl-radio__button",
bsw/jbe@1309:                       type = "radio", name = "disable_notifications", value = "false",
bsw/jbe@1309:                       checked = not app.session.member.disable_notifications and "checked" or nil,
bsw/jbe@1309:                     }
bsw/jbe@1309:                   }
bsw/jbe@1309:                   ui.tag{
bsw/jbe@1309:                     attr = { class = "mdl-radio__label", ['for'] = "notify_level_all" },
bsw/jbe@1309:                     content = _"I like to receive notifications"
bsw/jbe@1309:                   }
bsw/jbe@1309:                 end
bsw@1261:               }
bsw/jbe@1309:             end }
bsw/jbe@1309:             
bsw/jbe@1309:             
bsw/jbe@1309:             ui.container{ attr = { class = "view_on_notify_level_all_false", style = "margin-left: 3em;" }, content = function()
bsw/jbe@1309:               slot.put("
")
bsw/jbe@1309:             
bsw/jbe@1309:               ui.container{ content = _"You will receive status update notification on issue phase changes. Additionally you can subscribe for a regular digest including updates on initiative drafts and new suggestions." }
bsw/jbe@1309:               slot.put("
")
bsw/jbe@1309:               ui.container{ content = function()
bsw/jbe@1309:                 ui.tag{ tag = "label", attr = {
bsw/jbe@1309:                     class = "mdl-radio mdl-js-radio mdl-js-ripple-effect",
bsw/jbe@1309:                     ["for"] = "digest_on"
bsw/jbe@1309:                   },
bsw/jbe@1309:                   content = function()
bsw/jbe@1309:                     ui.tag{
bsw/jbe@1309:                       tag = "input", 
bsw/jbe@1309:                       attr = {
bsw/jbe@1309:                         id = "digest_on",
bsw/jbe@1309:                         class = "mdl-radio__button",
bsw/jbe@1309:                         type = "radio", name = "digest", value = "true",
bsw/jbe@1309:                         checked = (app.session.member.disable_notifications or app.session.member.notification_hour ~= nil) and "checked" or nil,
bsw/jbe@1309:                       }
bsw/jbe@1309:                     }
bsw/jbe@1309:                     ui.tag{
bsw/jbe@1309:                       attr = { class = "mdl-radio__label", ['for'] = "digest_on" },
bsw/jbe@1309:                       content = _"I want to receive a regular digest"
bsw/jbe@1309:                     }
bsw/jbe@1309:                   end
bsw/jbe@1309:                 }
bsw/jbe@1309:               end }
bsw/jbe@1309:           
bsw/jbe@1309:               ui.container{ attr = { class = "view_on_digest_true", style = "margin-left: 4em;" }, content = function()
bsw/jbe@1309: 
bsw/jbe@1309:                 ui.tag{ content = _"every" }
bsw/jbe@1309:                 slot.put(" ")
bsw/jbe@1309:                 ui.field.select{
bsw/jbe@1309:                   container_attr = { style = "display: inline-block; vertical-align: middle;" },
bsw/jbe@1309:                   attr = { style = "width: 10em;" },
bsw/jbe@1309:                   name = "notification_dow",
bsw/jbe@1309:                   foreign_records = {
bsw/jbe@1309:                     { id = "daily", name = _"day" },
bsw/jbe@1309:                     { id = 0, name = _"Sunday" },
bsw/jbe@1309:                     { id = 1, name = _"Monday" },
bsw/jbe@1309:                     { id = 2, name = _"Tuesday" },
bsw/jbe@1309:                     { id = 3, name = _"Wednesday" },
bsw/jbe@1309:                     { id = 4, name = _"Thursday" },
bsw/jbe@1309:                     { id = 5, name = _"Friday" },
bsw/jbe@1309:                     { id = 6, name = _"Saturday" }
bsw/jbe@1309:                   },
bsw/jbe@1309:                   foreign_id = "id",
bsw/jbe@1309:                   foreign_name = "name",
bsw/jbe@1309:                   value = app.session.member.notification_dow
bsw/jbe@1309:                 }
bsw/jbe@1309:                 
bsw/jbe@1309:                 slot.put(" ")
bsw/jbe@1309: 
bsw/jbe@1309:                 ui.tag{ content = _"between" }
bsw/jbe@1309:                 slot.put(" ")
bsw/jbe@1309:                 local foreign_records = {}
bsw/jbe@1309:                 for i = 0, 23 do
bsw/jbe@1309:                   foreign_records[#foreign_records+1] = {
bsw/jbe@1309:                     id = i,
bsw/jbe@1309:                     name = string.format("%02d:00 - %02d:59", i, i),
bsw/jbe@1309:                   }
bsw/jbe@1309:                 end
bsw/jbe@1309:                 local random_hour
bsw/jbe@1309:                 if app.session.member.disable_notifications or app.session.member.notification_hour == nil then
bsw/jbe@1309:                   random_hour = multirand.integer(0,23)
bsw/jbe@1309:                 end
bsw/jbe@1309:                 ui.field.select{
bsw/jbe@1309:                   container_attr = { style = "display: inline-block; vertical-align: middle;" },
bsw/jbe@1309:                   attr = { style = "width: 10em;" },
bsw/jbe@1309:                   name = "notification_hour",
bsw/jbe@1309:                   foreign_records = foreign_records,
bsw/jbe@1309:                   foreign_id = "id",
bsw/jbe@1309:                   foreign_name = "name",
bsw/jbe@1309:                   value = random_hour or app.session.member.notification_hour
bsw/jbe@1309:                 }
bsw/jbe@1309:               end }
bsw/jbe@1309:               
bsw/jbe@1309:               ui.container{ content = function()
bsw/jbe@1309:                 ui.tag{ tag = "label", attr = {
bsw/jbe@1309:                     class = "mdl-radio mdl-js-radio mdl-js-ripple-effect",
bsw/jbe@1309:                     ["for"] = "digest_off"
bsw/jbe@1309:                   },
bsw/jbe@1309:                   content = function()
bsw/jbe@1309:                     ui.tag{
bsw/jbe@1309:                       tag = "input", 
bsw/jbe@1309:                       attr = {
bsw/jbe@1309:                         id = "digest_off",
bsw/jbe@1309:                         class = "mdl-radio__button",
bsw/jbe@1309:                         type = "radio", name = "digest", value = "false",
bsw/jbe@1309:                         checked = not app.session.member.disable_notifications and app.session.member.notification_dow == nil and app.session.member.notification_hour == nil and "checked" or nil,
bsw/jbe@1309:                       }
bsw/jbe@1309:                     }
bsw/jbe@1309:                     ui.tag{
bsw/jbe@1309:                       tag = "label", attr = { class = "mdl-radio__label", ['for'] = "digest_off" },
bsw/jbe@1309:                       content = _"don't send me a digest"
bsw/jbe@1309:                     }
bsw/jbe@1309:                   end
bsw/jbe@1309:                 }
bsw/jbe@1309:               end }
bsw/jbe@1309:             end }
bsw/jbe@1309:             
bsw/jbe@1309:             slot.put("
")
bsw/jbe@1309:             
bsw/jbe@1309:             ui.container{ content = function()
bsw/jbe@1309:               ui.tag{ tag = "label", attr = {
bsw/jbe@1309:                   class = "mdl-radio mdl-js-radio mdl-js-ripple-effect",
bsw/jbe@1309:                   ["for"] = "notify_level_none"
bsw/jbe@1309:                 },
bsw/jbe@1309:                 content = function()
bsw/jbe@1309:                   ui.tag{
bsw/jbe@1309:                     tag = "input", 
bsw/jbe@1309:                     attr = {
bsw/jbe@1309:                       id = "notify_level_none",
bsw/jbe@1309:                       class = "mdl-radio__button",
bsw/jbe@1309:                       type = "radio", name = "disable_notifications", value = "true",
bsw/jbe@1309:                       checked = app.session.member.disable_notifications and "checked" or nil
bsw/jbe@1309:                     }
bsw/jbe@1309:                   }
bsw/jbe@1309:                   ui.tag{
bsw/jbe@1309:                     attr = { class = "mdl-radio__label", ['for'] = "notify_level_none" },
bsw/jbe@1309:                     content = _"don't send me notifications by email"
bsw/jbe@1309:                   }
bsw/jbe@1309:                 end
bsw/jbe@1309:               }
bsw/jbe@1309:             end }
bsw/jbe@1309:             
bsw/jbe@1309:             slot.put("
")
bsw/jbe@1309:           
bsw@1261:             ui.tag{
bsw/jbe@1309:               tag = "input",
bsw/jbe@1309:               attr = {
bsw/jbe@1309:                 type = "submit",
bsw/jbe@1309:                 class = "mdl-button mdl-js-button mdl-button--raised mdl-button--colored",
bsw/jbe@1309:                 value = _"Save"
bsw/jbe@1309:               },
bsw/jbe@1309:               content = ""
bsw@1261:             }
bsw/jbe@1309:             slot.put("   ")
bsw@1261:             
bsw@1261:             slot.put(" ")
bsw/jbe@1309:             if return_to == "home" then
bsw/jbe@1309:               ui.link {
bsw/jbe@1309:                 attr = { class = "mdl-button mdl-js-button mdl-button--raised" },
bsw/jbe@1309:                 module = "index", view = "index",
bsw/jbe@1309:                 content = _"cancel"
bsw/jbe@1309:               }
bsw/jbe@1309:             else
bsw/jbe@1309:               ui.link {
bsw/jbe@1309:                 attr = { class = "mdl-button mdl-js-button mdl-button--raised" },
bsw/jbe@1309:                 module = "member", view = "settings", 
bsw/jbe@1309:                 content = _"cancel"
bsw@1261:               }
bsw@1261:             end
bsw/jbe@1309:             
bsw/jbe@1309:           end
bsw/jbe@1309:         }
bsw@1255:         
bsw/jbe@1309:       end }
bsw/jbe@1309:     end }
bsw/jbe@1309:   end }
bsw@1282: 
bsw/jbe@1309:   ui.cell_sidebar{ content = function()
bsw/jbe@1309:     execute.view {
bsw/jbe@1309:       module = "member", view = "_sidebar_whatcanido", params = {
bsw/jbe@1309:         member = app.session.member
bsw/jbe@1309:       }
bsw/jbe@1309:     }
bsw/jbe@1309:   end }
bsw/jbe@1309: 
bsw/jbe@1309: end }