use parent qw(Rose::Object);
use SL::Presenter;
+ require SL::Layout::ActionBar::Submit;
use Rose::Object::MakeMethods::Generic (
'scalar --get_set_init' => [ qw(id params text) ],
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) = @_;
- require SL::Layout::ActionBar::Separator;
- require SL::Layout::ActionBar::ComboBox;
-
- return {
- separator => SL::Layout::ActionBar::Separator->new,
- combobox => SL::Layout::ActionBar::ComboBox->new,
- }->{$descriptor} or die 'unknown descriptor';
-}
-
-# TODO: this necessary?
-sub simple {
+# this is mostly so that outside consumer don't need to load subclasses themselves
+sub from_params {
my ($class, $data) = @_;
my ($text, %params) = @$data;
-
- if ($params{submit}) {
- require SL::Layout::ActionBar::Submit;
- 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 => \%params);
- }
-
- if ($params{actions}) {
- require SL::Layout::ActionBar::ComboBox;
- return SL::Layout::ActionBar::ComboBox->new(text => $text, %params);
- }
+ return SL::Layout::ActionBar::Submit->new(text => $text, params => \%params);
}
# shortcut for presenter
SL::Presenter->get
}
+sub init_params {
+ +{}
+}
+
# unique id to tie div and javascript together
sub init_id {
+ $_[0]->params->{id} //
$_[0]->p->name_to_id('action[]')
}
on click call the specified function (is this a special case of checks?)
-- disabled => true/false (done)
+- disabled => true/false/tooltip explaning why disabled (done)
TODO:
- runtime disable/enable
-