From 6cdf09812dd13531acb29f1413de87ce7cd5218f Mon Sep 17 00:00:00 2001 From: Petr Vobornik Date: Tue, 22 Nov 2011 16:00:48 +0100 Subject: Builders and collections for fields and widgets Introduced IPA.field_container and IPA.widget_container. IPA.field_container: collection for fields. Can set logical container (facet, dialog...) to fields. IPA.widget_container: collection for widgets. Has basic searching capability withing widget tree. Introduced field_builder, widget_builder, section_builder, details_builder. All are used for building fields and widgets. Field_builder and widget_builder have the main building logic. Section_builder can create content based on current section spec. Details builder defines a strategy for building content. https://fedorahosted.org/freeipa/ticket/2040 --- install/ui/details.js | 133 ++++++++++++++++++++++++++++++++++++++++++++++ install/ui/field.js | 97 ++++++++++++++++++++++++++++++++++ install/ui/widget.js | 143 ++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 373 insertions(+) (limited to 'install') diff --git a/install/ui/details.js b/install/ui/details.js index 440a9b7d..df14fd36 100644 --- a/install/ui/details.js +++ b/install/ui/details.js @@ -29,6 +29,139 @@ IPA.expanded_icon = 'expanded-icon'; IPA.collapsed_icon = 'collapsed-icon'; +IPA.details_builder = function(spec) { + + var that = {}; + + that.widgets = spec.container.widgets; + that.fields = spec.container.fields; + + that.widget_builder = spec.widget_builder || IPA.widget_builder(); + that.field_builder = spec.field_builder || IPA.field_builder(); + that.section_builder = spec.section_builder || IPA.section_builder(); + + that.build_widget = function(spec) { + + if (!spec) return; + + that.widget_builder.build_widget(spec, that.widgets); + }; + + that.build_widgets = function(specs) { + + if (!specs) return; + + that.widget_builder.build_widgets(specs, that.widgets); + }; + + that.build_field = function(spec) { + + if (!spec) return; + + that.field_builder.build_field(spec, that.fields); + }; + + that.build_fields = function(specs) { + + if (!specs) return; + + that.field_builder.build_fields(specs, that.fields); + }; + + that.build_sections = function(specs) { + + if (!specs) return; + + that.section_builder.build_sections(specs); + }; + + that.build = function(spec) { + + if (spec.sections) { + that.build_sections(spec.sections); + + } else if (spec.fields && !spec.widgets) { + + var sections = [ + { + fields: spec.fields + } + ]; + + that.build_sections(sections); + + } else { + that.build_fields(spec.fields); + that.build_widgets(spec.widgets); + } + }; + + return that; +}; + +IPA.section_builder = function(spec) { + + spec = spec || {}; + + var that = {}; + + that.container = spec.container; + that.section_factory = spec.section_factory || IPA.details_table_section; + + that.field_builder = spec.field_builder; + that.widget_builder = spec.widget_builder; + + that.build_sections = function(sections) { + + if(!sections) return; + + for (var i=0; i < sections.length; i++) { + that.build_section(sections[i], i); + } + }; + + that.build_section = function(section_spec, index) { + section_spec.entity = that.entity; + + if (!section_spec.label && section_spec.name) { + var obj_messages = IPA.messages.objects[that.container.entity.name]; + section_spec.label = obj_messages[section_spec.name]; + } + + if(!section_spec.name) section_spec.name = 'section'+index; + + section_spec.factory = section_spec.factory || that.section_factory; + var section = section_spec.factory(section_spec); + + that.container.widgets.add_widget(section); + + that.create_fields(section, section_spec.fields); + }; + + that.create_fields = function(section, fields_spec) { + + for (var i=0; i < fields_spec.length; i++) { + that.create_field(section, fields_spec[i]); + } + }; + + that.create_field = function(section, field_spec) { + + var widget = that.widget_builder.build_widget(field_spec, section.widgets); + + //spec.factory refers to widget factory + if(field_spec.factory) delete field_spec.factory; + + var field = that.field_builder.build_field(field_spec, that.container.fields); + + if(widget && field) { + field.widget_name = section.name+'.'+widget.name; + } + }; + + return that; +}; + IPA.details_section = function(spec) { spec = spec || {}; diff --git a/install/ui/field.js b/install/ui/field.js index fb14f2eb..c1b74ab5 100644 --- a/install/ui/field.js +++ b/install/ui/field.js @@ -572,6 +572,103 @@ IPA.link_field = function(spec) { return that; }; +IPA.field_container = function(spec) { + + spec = spec || {}; + + var that = {}; + + that.container = spec.container; //usually facet or dialog + + that.fields = $.ordered_map(); + + that.get_field = function(name) { + return that.fields.get(name); + }; + + that.get_fields = function(name) { + return that.fields.values; + }; + + that.add_field = function(field) { + field.container = that.container; + that.fields.put(field.name, field); + }; + + that.widgets_created = function() { + var fields = that.fields.values; + + for (var i=0; i= 0) { + name = path.substring(0, i); + child_path = path.substring(i + 1); + + child = that.widgets.get(name); + widget = child.widgets.get_widget(child_path); + } else { + widget = that.widgets.get(path); + } + + return widget; + }; + + that.get_widgets = function() { + return that.widgets.values; + }; + + that.create = function(container) { + + var widgets = that.widgets.values; + for (var i=0; i', { + name: widget.name, + title: widget.label, + 'class': widget['class'] + }).appendTo(container); + } + widget.create(child_container); + + if(i < widgets.length - 1) { + that.create_widget_delimiter(container); + } + } + }; + + that.clear = function() { + + var widgets = that.widgets.values; + for (var i=0; i