Hi,

This patch is based on Adam's bbq-tabs-modal branch.

The add.js has been modified to support adding new entry with
dynamically generated pkey.

The index.xhtml has been modified to include service.js.

The service.js has been modified to use the new API to define
the search, add, and details fields. Callbacks are used to
add quick links and generate pkey dynamically.

The webui.js has been modified to add the Services tab.

Thanks!

--
Endi S. Dewata
>From cf4703e9e62cfddbdfeceb21d811e0ece1c00886 Mon Sep 17 00:00:00 2001
From: Endi Sukma Dewata <edew...@redhat.com>
Date: Fri, 17 Sep 2010 19:03:50 -0400
Subject: [PATCH] Restoring Services tab.

The add.js has been modified to support adding new entry with
dynamically generated pkey.

The index.xhtml has been modified to include service.js.

The service.js has been modified to use the new API to define
the search, add, and details fields. Callbacks are used to
add quick links and generate pkey dynamically.

The webui.js has been modified to add the Services tab.
---
 install/static/add.js      |   12 ++--
 install/static/index.xhtml |    1 +
 install/static/service.js  |  165 ++++++++++++++++++++------------------------
 install/static/webui.js    |    1 +
 4 files changed, 83 insertions(+), 96 deletions(-)

diff --git a/install/static/add.js b/install/static/add.js
index c657cfe..71d0833 100644
--- a/install/static/add.js
+++ b/install/static/add.js
@@ -28,21 +28,19 @@ function add_dialog_create(obj_name, adl)
     var add_dialog = $('<div></div>');
 
     function add(evt, called_from_add_and_edit) {
+        var pkey = [];
+        var options = {};
+        var pkey_name = ipa_objs[obj_name].primary_key;
+
         function add_win(data, text_status, xhr) {
             if (called_from_add_and_edit) {
                 var state = {};
                 state[obj_name + '-facet'] = 'details';
-                var pkey_name = ipa_objs[obj_name].primary_key;
-                var selector = 'input[name=' + pkey_name + ']';
-                state[obj_name + '-pkey'] = add_dialog.find(selector).val();
+                state[obj_name + '-pkey'] = pkey[0];
                 $.bbq.pushState(state);
             }
         };
 
-        var pkey = [];
-        var options = {};
-        var pkey_name = ipa_objs[obj_name].primary_key;
-
         var fields = adl[2];
         for (var i = 0; i < fields.length; ++i) {
             var f = fields[i];
diff --git a/install/static/index.xhtml b/install/static/index.xhtml
index ce29718..98e2495 100644
--- a/install/static/index.xhtml
+++ b/install/static/index.xhtml
@@ -24,6 +24,7 @@
     <script type="text/javascript" src="host.js"></script>
     <script type="text/javascript" src="hostgroup.js"></script>
     <script type="text/javascript" src="netgroup.js"></script>
+    <script type="text/javascript" src="service.js"></script>
 
     <script type="text/javascript" src="develop.js"></script>
     <script type="text/javascript" src="webui.js"></script>
diff --git a/install/static/service.js b/install/static/service.js
index 852415f..0fd5457 100644
--- a/install/static/service.js
+++ b/install/static/service.js
@@ -1,93 +1,80 @@
-function setupService(facet) {
-    serviceForms.setup(facet);
-}
-
-var serviceForms = new ServiceForms();
-
-function ServiceForms() {
-
-    this.obj = "service";
-
-    this.facets = ['details', 'hosts', 'assignhosts'];
-
-    this.setup = function(facet) {
-        if (this[facet]) {
-            this[facet].setup();
-        } else {
-            this.unspecified.setup();
+/*  Authors:
+ *    Endi Sukma Dewata <edew...@redhat.com>
+ *
+ * Copyright (C) 2010 Red Hat
+ * see file 'COPYING' for use and warranty information
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 only
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+/* REQUIRES: ipa.js, details.js, search.js, add.js, entity.js */
+
+ipa_entity_set_search_definition('service', [
+    ['krbprincipalname', 'Principal', null],
+    ['quick_links', 'Quick Links', service_render_quick_links]
+]);
+
+ipa_entity_set_add_definition('service', [
+    'dialog-add-service', 'Add New Service', [
+        ['krbprincipalname', 'Principal', service_add_krbprincipalname],
+        ['service', 'Service', null],
+        ['host', 'Host Name', null],
+    ]
+]);
+
+ipa_entity_set_details_definition('service', [
+    ['identity', 'Service Details', [
+        ['krbprincipalname', 'Principal', null],
+    ]]
+]);
+
+function service_render_quick_links(tr, attr, value, entry_attrs) {
+
+    var td = $("<td/>");
+    tr.append(td);
+
+    $("<a/>", {
+        href: "jslink",
+        html: "[D]",
+        click: function() {
+            var state = {};
+            state['service-facet'] = 'details';
+            state['service-pkey'] = entry_attrs['krbprincipalname'][0];
+            $.bbq.pushState(state);
+            return false;
         }
-    };
-
-    this.hostListColumns = [ {title:"host",column:"managedby_host"} ];
-
-    this.hosts = new AssociationList(
-        this.obj,
-        "hosts",
-        "assignhosts",
-        this.hostListColumns,
-        this.facets
-    );
-
-    this.assignhosts = new AssociationForm(
-        this.obj,
-        "host",
-        "assignhosts",
-        this.facets,
-        "fqdn",
-        function() {
-            return 'Add Hosts to service : ' + qs['pkey'];
-        },
-        BulkAssociator,
-        "add_host"
-    );
-
-    this.detailsList = [
-        ['identity', 'Service Details', [
-            ['krbprincipalname', 'Kerberos Principal']
-        ]]
-    ];
-
-    this.details = new DetailsForm(
-        "service",
-        this.detailsList,
-        "krbprincipalname",
-        this.facets
-    );
-
-    this.addProperties = [
-        {title: 'Service', id: 'service', type: 'text'},
-        {title: 'Host Name', id: 'host', type: 'text'}
-    ];
-
-    this.add = new EntityBuilder(
-        "service",
-        this.addProperties
-    );
-
-    this.add.getPKey = function() {
-        return $("#service").val()+"/"+$("#host").val();
-    }
-
-    this.searchColumns = [
-        {
-            title: "Service",
-            column: "krbprincipalname",
-            render: function (current, cell) {
-                renderPkeyColumn2('service', 'krbprincipalname', current, cell);
-            }
-        },
-        {
-            title: "Has Keytab",
-            column: "has_keytab",
-            render: renderSimpleColumn
+    }).appendTo(td);
+
+    $("<a/>", {
+        href: "jslink",
+        html: "[G]",
+        click: function() {
+            var state = {};
+            state['service-facet'] = 'associate';
+            state['service-enroll'] = 'host';
+            state['service-pkey'] = entry_attrs['krbprincipalname'][0];
+            $.bbq.pushState(state);
+            return false;
         }
-    ];
-
-    this.search = new SearchForm(
-        "service",
-        "find",
-        this.searchColumns
-    );
+    }).appendTo(td);
+}
 
-    this.unspecified = this.search;
+function service_add_krbprincipalname(add_dialog, flag) {
+    if (flag == IPA_ADD_UPDATE) {
+        var service = add_dialog.find('input[name=service]').val();
+        var host = add_dialog.find('input[name=host]').val();
+        return service+'/'+host;
+    }
+    return null;
 }
diff --git a/install/static/webui.js b/install/static/webui.js
index f7cccff..9aaa21d 100644
--- a/install/static/webui.js
+++ b/install/static/webui.js
@@ -28,6 +28,7 @@ var nav_tabs_lists = [
         ['host', 'Hosts', ipa_entity_setup],
         ['hostgroup', 'Hostgroups', ipa_entity_setup],
         ['netgroup', 'Netgroups', ipa_entity_setup],
+        ['service', 'Services', ipa_entity_setup],
     ]],
     ['policy', 'POLICY', unimplemented_tab],
     ['config', 'CONFIG', unimplemented_tab]
-- 
1.7.2.2

_______________________________________________
Freeipa-devel mailing list
Freeipa-devel@redhat.com
https://www.redhat.com/mailman/listinfo/freeipa-devel

Reply via email to