diff options
author | Matthew Wild <mwild1@gmail.com> | 2013-04-23 15:38:38 +0100 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2013-04-23 15:38:38 +0100 |
commit | c953a057a8fb1e0b0617dd090ab4ff7a643956c3 (patch) | |
tree | 6c5314d0829139cb9ef4d305679085eb744b1577 /util/adhoc.lua | |
parent | 9c847957b9e4e7a90fcdf39ac349f48eb93c4a21 (diff) | |
parent | 5468423a19fc09b010d0c4aa92e486ecbe0c9dae (diff) | |
download | prosody-c953a057a8fb1e0b0617dd090ab4ff7a643956c3.tar.gz prosody-c953a057a8fb1e0b0617dd090ab4ff7a643956c3.zip |
Merge 0.9->trunk
Diffstat (limited to 'util/adhoc.lua')
-rw-r--r-- | util/adhoc.lua | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/util/adhoc.lua b/util/adhoc.lua new file mode 100644 index 00000000..671e85cf --- /dev/null +++ b/util/adhoc.lua @@ -0,0 +1,31 @@ +local function new_simple_form(form, result_handler) + return function(self, data, state) + if state then + if data.action == "cancel" then + return { status = "canceled" }; + end + local fields, err = form:data(data.form); + return result_handler(fields, err, data); + else + return { status = "executing", actions = {"next", "complete", default = "complete"}, form = form }, "executing"; + end + end +end + +local function new_initial_data_form(form, initial_data, result_handler) + return function(self, data, state) + if state then + if data.action == "cancel" then + return { status = "canceled" }; + end + local fields, err = form:data(data.form); + return result_handler(fields, err, data); + else + return { status = "executing", actions = {"next", "complete", default = "complete"}, + form = { layout = form, values = initial_data() } }, "executing"; + end + end +end + +return { new_simple_form = new_simple_form, + new_initial_data_form = new_initial_data_form }; |