X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/e0a3b19e35aed6f3f8ba84e25381a5d0e6ca61f4..dd1ab30b7c2a6bec318dd75100e54c9bfa400e77:/SL/Layout/ActionBar/Action.pm diff --git a/SL/Layout/ActionBar/Action.pm b/SL/Layout/ActionBar/Action.pm index 454255c8c..8b83295c5 100644 --- a/SL/Layout/ActionBar/Action.pm +++ b/SL/Layout/ActionBar/Action.pm @@ -6,7 +6,7 @@ use parent qw(Rose::Object); use SL::Presenter; use Rose::Object::MakeMethods::Generic ( - 'scalar --get_set_init' => [ qw(id) ], + 'scalar --get_set_init' => [ qw(id params text) ], ); # subclassing interface @@ -16,18 +16,20 @@ sub render { } sub script { - die 'needs to be implemented'; + sprintf q|$('#%s').data('action', %s);|, $_[0]->id, JSON->new->allow_blessed->convert_blessed->encode($_[0]->params); } - # static constructors sub from_descriptor { - my ($class, $descriptor) = @_;a + my ($class, $descriptor) = @_; + require SL::Layout::ActionBar::Separator; + require SL::Layout::ActionBar::ComboBox; - { + return { separator => SL::Layout::ActionBar::Separator->new, - } or die 'unknown descriptor'; + combobox => SL::Layout::ActionBar::ComboBox->new, + }->{$descriptor} or die 'unknown descriptor'; } # TODO: this necessary? @@ -38,16 +40,17 @@ sub simple { if ($params{submit}) { require SL::Layout::ActionBar::Submit; - return SL::Layout::ActionBar::Submit->new(text => $text, %params); + return SL::Layout::ActionBar::Submit->new(text => $text, params => \%params); } if ($params{function}) { require SL::Layout::ActionBar::ScriptButton; - return SL::Layout::ActionBar::ScriptButton->new(text => $text, %params); + return SL::Layout::ActionBar::ScriptButton->new(text => $text, params => \%params); } - if ($params{combobox}) { - + if ($params{actions}) { + require SL::Layout::ActionBar::ComboBox; + return SL::Layout::ActionBar::ComboBox->new(text => $text, %params); } } @@ -66,3 +69,26 @@ sub init_id { 1; __END__ + +=head 1 + +planned options for clickables: + +- checks => [ ... ] (done) + +a list of functions that need to return true before submitting + +- submit => [ form-selector, { params } ] (done) + +on click submit the form specified by form-selector with the additional params + +- function => function-name (done) + +on click call the specified function (is this a special case of checks?) + +- disabled => true/false (done) + +TODO: + +- runtime disable/enable +