Repository: nifi-registry
Updated Branches:
  refs/heads/master 168708927 -> 7b707a05d


http://git-wip-us.apache.org/repos/asf/nifi-registry/blob/7b707a05/nifi-registry-web-ui/src/main/webapp/services/nf-registry.service.spec.js
----------------------------------------------------------------------
diff --git 
a/nifi-registry-web-ui/src/main/webapp/services/nf-registry.service.spec.js 
b/nifi-registry-web-ui/src/main/webapp/services/nf-registry.service.spec.js
new file mode 100644
index 0000000..64c6359
--- /dev/null
+++ b/nifi-registry-web-ui/src/main/webapp/services/nf-registry.service.spec.js
@@ -0,0 +1,424 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the 'License'); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *     http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+var NfRegistryRoutes = require('nifi-registry/nf-registry.routes.js');
+var ngCoreTesting = require('@angular/core/testing');
+var ngHttpTesting = require('@angular/http/testing');
+var ngCommon = require('@angular/common');
+var FdsDemo = 
require('nifi-registry/components/fluid-design-system/fds-demo.js');
+var NfRegistry = require('nifi-registry/nf-registry.js');
+var NfRegistryApi = require('nifi-registry/services/nf-registry.api.js');
+var NfRegistryService = 
require('nifi-registry/services/nf-registry.service.js');
+var NfPageNotFoundComponent = 
require('nifi-registry/components/page-not-found/nf-registry-page-not-found.js');
+var NfRegistryExplorer = 
require('nifi-registry/components/explorer/nf-registry-explorer.js');
+var NfRegistryAdministration = 
require('nifi-registry/components/administration/nf-registry-administration.js');
+var NfRegistryGeneralAdministration = 
require('nifi-registry/components/administration/general/nf-registry-general-administration.js');
+var NfRegistryUsersAdministration = 
require('nifi-registry/components/administration/users/nf-registry-users-administration.js');
+var NfRegistryAddUser = 
require('nifi-registry/components/administration/users/add/nf-registry-add-user.js');
+var NfRegistryUserDetails = 
require('nifi-registry/components/administration/users/details/nf-registry-user-details.js');
+var NfRegistryUserPermissions = 
require('nifi-registry/components/administration/users/permissions/nf-registry-user-permissions.js');
+var NfRegistryBucketPermissions = 
require('nifi-registry/components/administration/workflow/buckets/permissions/nf-registry-bucket-permissions.js');
+var NfRegistryWorkflowAdministration = 
require('nifi-registry/components/administration/workflow/nf-registry-workflow-administration.js');
+var NfRegistryGridListViewer = 
require('nifi-registry/components/explorer/grid-list/registry/nf-registry-grid-list-viewer.js');
+var NfRegistryBucketGridListViewer = 
require('nifi-registry/components/explorer/grid-list/registry/nf-registry-bucket-grid-list-viewer.js');
+var NfRegistryDropletGridListViewer = 
require('nifi-registry/components/explorer/grid-list/registry/nf-registry-droplet-grid-list-viewer.js');
+var fdsCore = require('@fluid-design-system/core');
+var ngMoment = require('angular2-moment');
+var ngHttp = require('@angular/http');
+var rxjs = require('rxjs/Rx');
+
+describe('NfRegistry Service isolated unit tests', function () {
+    var comp;
+    var fixture;
+    var nfRegistryService;
+
+    beforeEach(function () {
+        nfRegistryService = new NfRegistryService();
+    });
+
+    it('should set the breadcrumb animation state', function () {
+        // The function to test
+        nfRegistryService.setBreadcrumbState('test');
+
+        //assertions
+        expect(nfRegistryService.breadCrumbState).toBe('test');
+    });
+
+    it('should get the `Name (z - a)` sort by label', function () {
+        //Setup the nfRegistryService state for this test
+        nfRegistryService.dropletColumns[0].active = true;
+
+        // The function to test
+        var label = nfRegistryService.getSortByLabel();
+
+        //assertions
+        expect(label).toBe('Name (z - a)');
+    });
+
+    it('should get the `Name (a - z)` sort by label', function () {
+        //Setup the nfRegistryService state for this test
+        nfRegistryService.dropletColumns[0].active = true;
+        nfRegistryService.dropletColumns[0].sortOrder = 'ASC';
+
+        // The function to test
+        var label = nfRegistryService.getSortByLabel();
+
+        //assertions
+        expect(label).toBe('Name (a - z)');
+    });
+
+    it('should get the `Oldest (update)` sort by label', function () {
+        //Setup the nfRegistryService state for this test
+        nfRegistryService.dropletColumns[1].active = true;
+
+        // The function to test
+        var label = nfRegistryService.getSortByLabel();
+
+        //assertions
+        expect(label).toBe('Oldest (update)');
+    });
+
+    it('should get the `Newest (update)` sort by label', function () {
+        //Setup the nfRegistryService state for this test
+        nfRegistryService.dropletColumns[1].active = true;
+        nfRegistryService.dropletColumns[1].sortOrder = 'ASC';
+
+        // The function to test
+        var label = nfRegistryService.getSortByLabel();
+
+        //assertions
+        expect(label).toBe('Newest (update)');
+    });
+
+    it('should generate the sort menu\'s `Name (a - z)` label', function () {
+        // The function to test
+        var label = nfRegistryService.generateSortMenuLabels({name: 'name', 
label: 'Name', sortable: true});
+
+        //assertions
+        expect(label).toBe('Name (a - z)');
+    });
+
+    it('should generate the sort menu\'s `Name (z - a)` label', function () {
+        // The function to test
+        var label = nfRegistryService.generateSortMenuLabels({
+            name: 'name',
+            label: 'Name',
+            sortable: true,
+            sortOrder: 'ASC'
+        });
+
+        //assertions
+        expect(label).toBe('Name (z - a)');
+    });
+
+    it('should generate the sort menu\'s `Newest (update)` label', function () 
{
+        // The function to test
+        var label = nfRegistryService.generateSortMenuLabels({name: 'updated', 
label: 'Updated', sortable: true});
+
+        //assertions
+        expect(label).toBe('Newest (update)');
+    });
+
+    it('should generate the sort menu\'s `Oldest (update)` label', function () 
{
+        // The function to test
+        var label = nfRegistryService.generateSortMenuLabels({
+            name: 'updated',
+            label: 'Updated',
+            sortable: true,
+            sortOrder: 'ASC'
+        });
+
+        //assertions
+        expect(label).toBe('Oldest (update)');
+    });
+
+    it('should sort `droplets` by `column`', function () {
+        //Spy
+        spyOn(nfRegistryService, 'filterDroplets').and.callFake(function () {
+        });
+
+        // object to be updated by the test
+        var column = {name: 'name', label: 'Name', sortable: true};
+
+        // The function to test
+        var label = nfRegistryService.sortDroplets(column);
+
+        //assertions
+        expect(column.active).toBe(true);
+        var filterDropletsCall = 
nfRegistryService.filterDroplets.calls.first();
+        expect(filterDropletsCall.args[0]).toBe('name');
+        expect(filterDropletsCall.args[1]).toBe('ASC');
+        expect(nfRegistryService.activeDropletColumn).toBe(column);
+    });
+
+    it('should generate the auto complete options for the droplet filter.', 
function () {
+        //Setup the nfRegistryService state for this test
+        nfRegistryService.filteredDroplets = [{
+            'identifier': '2e04b4fb-9513-47bb-aa74-1ae34616bfdc',
+            'name': 'Flow #1',
+            'description': 'This is flow #1',
+            'bucketIdentifier': '2f7f9e54-dc09-4ceb-aa58-9fe581319cdc',
+            'createdTimestamp': 1505931890999,
+            'modifiedTimestamp': 1505931890999,
+            'type': 'FLOW',
+            'snapshotMetadata': null,
+            'link': {
+                'params': {
+                    'rel': 'self'
+                },
+                'href': 'flows/2e04b4fb-9513-47bb-aa74-1ae34616bfdc'
+            }
+        }];
+
+        // The function to test
+        nfRegistryService.getAutoCompleteDroplets();
+
+        //assertions
+        
expect(nfRegistryService.autoCompleteDroplets[0]).toBe(nfRegistryService.filteredDroplets[0].name);
+    });
+});
+
+describe('NfRegistry Service w/ Angular testing utils', function () {
+    var comp;
+    var fixture;
+    var nfRegistryService;
+
+    beforeEach(function () {
+        ngCoreTesting.TestBed.configureTestingModule({
+            imports: [
+                ngMoment.MomentModule,
+                ngHttp.HttpModule,
+                ngHttp.JsonpModule,
+                fdsCore,
+                NfRegistryRoutes
+            ],
+            declarations: [
+                FdsDemo,
+                NfRegistry,
+                NfRegistryExplorer,
+                NfRegistryAdministration,
+                NfRegistryGeneralAdministration,
+                NfRegistryUsersAdministration,
+                NfRegistryUserDetails,
+                NfRegistryUserPermissions,
+                NfRegistryBucketPermissions,
+                NfRegistryAddUser,
+                NfRegistryWorkflowAdministration,
+                NfRegistryGridListViewer,
+                NfRegistryBucketGridListViewer,
+                NfRegistryDropletGridListViewer,
+                NfPageNotFoundComponent
+            ],
+            providers: [
+                NfRegistryService,
+                NfRegistryApi,
+                {
+                    provide: ngCommon.APP_BASE_HREF,
+                    useValue: '/'
+                },
+                {
+                    provide: ngHttp.XHRBackend,
+                    useClass: ngHttpTesting.MockBackend
+                }
+            ],
+            bootstrap: [NfRegistry]
+        });
+
+        fixture = 
ngCoreTesting.TestBed.createComponent(NfRegistryDropletGridListViewer);
+
+        // test instance
+        comp = fixture.componentInstance;
+
+        // from the root injector
+        nfRegistryService = ngCoreTesting.TestBed.get(NfRegistryService);
+        nfRegistryApi = ngCoreTesting.TestBed.get(NfRegistryApi);
+
+        fixture.detectChanges();
+
+        // Spy
+        spyOn(nfRegistryApi.http, 'get').and.callThrough();
+    });
+
+    it('should retrieve the snapshot metadata for the given droplet.', 
ngCoreTesting.fakeAsync(function () {
+        //Spy
+        spyOn(nfRegistryService.api, 
'getDropletSnapshotMetadata').and.callFake(function(){}).and.returnValue(rxjs.Observable.of([{
+            version: 999
+        }]));
+
+        // object to be updated by the test
+        var droplet = {link: {href: 'test/id'}};
+
+        // The function to test
+        nfRegistryService.getDropletSnapshotMetadata(droplet);
+
+        // wait for async getDropletSnapshotMetadata call
+        ngCoreTesting.tick();
+
+        //inform angular to detect changes
+        fixture.detectChanges();
+
+        //assertions
+        expect(droplet.snapshotMetadata[0].version).toBe(999);
+        
expect(nfRegistryService.api.getDropletSnapshotMetadata).toHaveBeenCalled();
+        
expect(nfRegistryService.api.getDropletSnapshotMetadata.calls.count()).toBe(1);
+        var getDropletSnapshotMetadataCall = 
nfRegistryService.api.getDropletSnapshotMetadata.calls.first()
+        expect(getDropletSnapshotMetadataCall.args[0]).toBe('test/id');
+        expect(getDropletSnapshotMetadataCall.args[1]).toBe(true);
+    }));
+
+    it('should execute the `delete` droplet action.', 
ngCoreTesting.fakeAsync(function () {
+        //Setup the nfRegistryService state for this test
+        nfRegistryService.droplets = [{identifier: 
'2e04b4fb-9513-47bb-aa74-1ae34616bfdc'}];
+
+        //Spy
+        spyOn(nfRegistryService.dialogService, 'openConfirm').and.returnValue({
+            afterClosed: function () {
+                return rxjs.Observable.of(true);
+            }
+        });
+        spyOn(nfRegistryService.api, 
'deleteDroplet').and.callFake(function(){}).and.returnValue(rxjs.Observable.of({identifier:
 '2e04b4fb-9513-47bb-aa74-1ae34616bfdc'}));
+        spyOn(nfRegistryService, 'filterDroplets').and.callFake(function () {
+        });
+
+        // The function to test
+        nfRegistryService.executeDropletAction({name: 'delete'}, {
+            identifier: '2e04b4fb-9513-47bb-aa74-1ae34616bfdc',
+            type: 'testTYPE',
+            link: {href: 'testhref'}
+        });
+
+        // wait for async nfRegistryService.api.deleteDroplet call
+        ngCoreTesting.tick();
+
+        //inform angular to detect changes
+        fixture.detectChanges();
+
+        //assertions
+        expect(nfRegistryService.droplets.length).toBe(0);
+        expect(nfRegistryService.filterDroplets).toHaveBeenCalled();
+        var openConfirmCall = 
nfRegistryService.dialogService.openConfirm.calls.first()
+        expect(openConfirmCall.args[0].title).toBe('Delete testtype');
+        var deleteDropletCall = 
nfRegistryService.api.deleteDroplet.calls.first()
+        expect(deleteDropletCall.args[0]).toBe('testhref');
+    }));
+
+    it('should filter droplets by name.', ngCoreTesting.fakeAsync(function () {
+        //Setup the nfRegistryService state for this test
+        nfRegistryService.dropletsSearchTerms = ['Flow #1'];
+        nfRegistryService.droplets = [{
+            'identifier': '2e04b4fb-9513-47bb-aa74-1ae34616bfdc',
+            'name': 'Flow #1',
+            'description': 'This is flow #1',
+            'bucketIdentifier': '2f7f9e54-dc09-4ceb-aa58-9fe581319cdc',
+            'createdTimestamp': 1505931890999,
+            'modifiedTimestamp': 1505931890999,
+            'type': 'FLOW',
+            'snapshotMetadata': null,
+            'link': {
+                'params': {
+                    'rel': 'self'
+                },
+                'href': 'flows/2e04b4fb-9513-47bb-aa74-1ae34616bfdc'
+            }
+        }, {
+            'identifier': '5d04b4fb-9513-47bb-aa74-1ae34616bfdc',
+            'name': 'Flow #2',
+            'description': 'This is flow #2',
+            'bucketIdentifier': '3g7f9e54-dc09-4ceb-aa58-9fe581319cdc',
+            'createdTimestamp': 1505931890999,
+            'modifiedTimestamp': 1505931890999,
+            'type': 'FLOW',
+            'snapshotMetadata': null,
+            'link': {
+                'params': {
+                    'rel': 'self'
+                },
+                'href': 'flows/5d04b4fb-9513-47bb-aa74-1ae34616bfdc'
+            }
+        }];
+
+        //Spy
+        spyOn(nfRegistryService, 'getAutoCompleteDroplets');
+
+        // The function to test
+        nfRegistryService.filterDroplets();
+
+        // wait for async nfRegistryService.api.deleteDroplet call
+        ngCoreTesting.tick();
+
+        //inform angular to detect changes
+        fixture.detectChanges();
+
+        //assertions
+        expect(nfRegistryService.filteredDroplets.length).toBe(1);
+        expect(nfRegistryService.filteredDroplets[0].name).toBe('Flow #1');
+        expect(nfRegistryService.getAutoCompleteDroplets).toHaveBeenCalled();
+    }));
+
+    it('should filter droplets by `type:flow` (demonstrate ability to do 
advanced searching of a droplet by a property `name:value` pair).', 
ngCoreTesting.fakeAsync(function () {
+        //Setup the nfRegistryService state for this test
+        nfRegistryService.dropletsSearchTerms = ['type:FLOW'];
+        nfRegistryService.droplets = [{
+            'identifier': '2e04b4fb-9513-47bb-aa74-1ae34616bfdc',
+            'name': 'Flow #1',
+            'description': 'This is flow #1',
+            'bucketIdentifier': '2f7f9e54-dc09-4ceb-aa58-9fe581319cdc',
+            'createdTimestamp': 1505931890999,
+            'modifiedTimestamp': 1505931890999,
+            'type': 'FLOW',
+            'snapshotMetadata': null,
+            'link': {
+                'params': {
+                    'rel': 'self'
+                },
+                'href': 'flows/2e04b4fb-9513-47bb-aa74-1ae34616bfdc'
+            }
+        }, {
+            'identifier': '5d04b4fb-9513-47bb-aa74-1ae34616bfdc',
+            'name': 'Flow #2',
+            'description': 'This is not a flow #2',
+            'bucketIdentifier': '3g7f9e54-dc09-4ceb-aa58-9fe581319cdc',
+            'createdTimestamp': 1505931890999,
+            'modifiedTimestamp': 1505931890999,
+            'type': 'something',
+            'snapshotMetadata': null,
+            'link': {
+                'params': {
+                    'rel': 'self'
+                },
+                'href': 'flows/5d04b4fb-9513-47bb-aa74-1ae34616bfdc'
+            }
+        }];
+
+        //Spy
+        spyOn(nfRegistryService, 'getAutoCompleteDroplets');
+
+        // The function to test
+        nfRegistryService.filterDroplets();
+
+        // wait for async nfRegistryService.api.deleteDroplet call
+        ngCoreTesting.tick();
+
+        //inform angular to detect changes
+        fixture.detectChanges();
+
+        //assertions
+        expect(nfRegistryService.filteredDroplets.length).toBe(1);
+        expect(nfRegistryService.filteredDroplets[0].name).toBe('Flow #1');
+        expect(nfRegistryService.getAutoCompleteDroplets).toHaveBeenCalled();
+    }));
+});
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/nifi-registry/blob/7b707a05/nifi-registry-web-ui/src/main/webapp/systemjs.builder.config.js
----------------------------------------------------------------------
diff --git a/nifi-registry-web-ui/src/main/webapp/systemjs.builder.config.js 
b/nifi-registry-web-ui/src/main/webapp/systemjs.builder.config.js
index 1d96854..34d02e0 100644
--- a/nifi-registry-web-ui/src/main/webapp/systemjs.builder.config.js
+++ b/nifi-registry-web-ui/src/main/webapp/systemjs.builder.config.js
@@ -71,6 +71,8 @@
             'switchMap': 'npm:rxjs/add/operator/switchMap',
             'zone.js': 'npm:zone.js/dist/zone.js',
             'core-js': 'npm:core-js/client/shim.min.js',
+            'superagent': 'npm:superagent/superagent.js',
+            'querystring': 'npm:querystring',
 
             // Fluid Design System
             '@fluid-design-system/core': 
'npm:@fluid-design-system/dist/platform/core/fluid-design-system.module.js',
@@ -85,11 +87,10 @@
             'nifi-registry/nf-registry.routes.js': 'nf-registry.routes.js',
             'nifi-registry/components/fluid-design-system/fds-demo.js': 
'components/fluid-design-system/fds-demo.js',
             'nifi-registry/nf-registry.js': 'nf-registry.js',
+            'nifi-registry/services/nf-registry.api.js': 
'services/nf-registry.api.js',
             'nifi-registry/services/nf-registry.service.js': 
'services/nf-registry.service.js',
             
'nifi-registry/components/page-not-found/nf-registry-page-not-found.js': 
'components/page-not-found/nf-registry-page-not-found.js',
             'nifi-registry/components/explorer/nf-registry-explorer.js': 
'components/explorer/nf-registry-explorer.js',
-            
'nifi-registry/components/explorer/list/nf-registry-explorer-list-viewer.js': 
'components/explorer/list/nf-registry-explorer-list-viewer.js',
-            
'nifi-registry/components/explorer/grid-list/nf-registry-explorer-grid-list-viewer.js':
 'components/explorer/grid-list/nf-registry-explorer-grid-list-viewer.js',
             
'nifi-registry/components/administration/nf-registry-administration.js': 
'components/administration/nf-registry-administration.js',
             
'nifi-registry/components/administration/general/nf-registry-general-administration.js':
 'components/administration/general/nf-registry-general-administration.js',
             
'nifi-registry/components/administration/users/nf-registry-users-administration.js':
 'components/administration/users/nf-registry-users-administration.js',
@@ -98,15 +99,9 @@
             
'nifi-registry/components/administration/users/permissions/nf-registry-user-permissions.js':
 'components/administration/users/permissions/nf-registry-user-permissions.js',
             
'nifi-registry/components/administration/workflow/buckets/permissions/nf-registry-bucket-permissions.js':
 
'components/administration/workflow/buckets/permissions/nf-registry-bucket-permissions.js',
             
'nifi-registry/components/administration/workflow/nf-registry-workflow-administration.js':
 'components/administration/workflow/nf-registry-workflow-administration.js',
-            
'nifi-registry/components/explorer/list/registry/nf-registry-list-viewer.js': 
'components/explorer/list/registry/nf-registry-list-viewer.js',
             
'nifi-registry/components/explorer/grid-list/registry/nf-registry-grid-list-viewer.js':
 'components/explorer/grid-list/registry/nf-registry-grid-list-viewer.js',
-            
'nifi-registry/components/explorer/list/registry/bucket/nf-registry-bucket-list-viewer.js':
 'components/explorer/list/registry/bucket/nf-registry-bucket-list-viewer.js',
-            
'nifi-registry/components/explorer/grid-list/registry/bucket/nf-registry-bucket-grid-list-viewer.js':
 
'components/explorer/grid-list/registry/bucket/nf-registry-bucket-grid-list-viewer.js',
-            
'nifi-registry/components/explorer/list/registry/bucket/droplet/nf-registry-droplet-list-viewer.js':
 
'components/explorer/list/registry/bucket/droplet/nf-registry-droplet-list-viewer.js',
-            
'nifi-registry/components/explorer/grid-list/registry/bucket/droplet/nf-registry-droplet-grid-list-viewer.js':
 
'components/explorer/grid-list/registry/bucket/droplet/nf-registry-droplet-grid-list-viewer.js',
-            
'nifi-registry/components/explorer/list/registry/nf-registry-details-viewer.js':
 'components/explorer/list/registry/nf-registry-details-viewer.js',
-            
'nifi-registry/components/explorer/list/registry/bucket/nf-registry-bucket-details-viewer.js':
 
'components/explorer/list/registry/bucket/nf-registry-bucket-details-viewer.js',
-            
'nifi-registry/components/explorer/list/registry/bucket/droplet/nf-registry-droplet-details-viewer.js':
 
'components/explorer/list/registry/bucket/droplet/nf-registry-droplet-details-viewer.js'
+            
'nifi-registry/components/explorer/grid-list/registry/nf-registry-bucket-grid-list-viewer.js':
 
'components/explorer/grid-list/registry/nf-registry-bucket-grid-list-viewer.js',
+            
'nifi-registry/components/explorer/grid-list/registry/nf-registry-droplet-grid-list-viewer.js':
 
'components/explorer/grid-list/registry/nf-registry-droplet-grid-list-viewer.js'
         },
         // packages tells the System loader how to load when no filename 
and/or no extension
         packages: {
@@ -124,6 +119,10 @@
             'rxjs': {
                 defaultExtension: 'js'
             },
+            'querystring': {
+                main: './index.js',
+                defaultExtension: 'js'
+            },
             'moment': {
                 main: './moment.js',
                 defaultExtension: 'js'

http://git-wip-us.apache.org/repos/asf/nifi-registry/blob/7b707a05/nifi-registry-web-ui/src/main/webapp/systemjs.spec.config.js
----------------------------------------------------------------------
diff --git a/nifi-registry-web-ui/src/main/webapp/systemjs.spec.config.js 
b/nifi-registry-web-ui/src/main/webapp/systemjs.spec.config.js
index a9d72c6..384c5e0 100644
--- a/nifi-registry-web-ui/src/main/webapp/systemjs.spec.config.js
+++ b/nifi-registry-web-ui/src/main/webapp/systemjs.spec.config.js
@@ -50,10 +50,20 @@
 
             // other libraries
             'rxjs': 'npm:rxjs',
+            'moment': 'npm:moment',
+            'angular2-moment': 'npm:angular2-moment',
             'switchMap': 'npm:rxjs/add/operator/switchMap',
+            'zone.js': 'npm:zone.js/dist/zone.js',
+            'core-js': 'npm:core-js/client/shim.min.js',
+            'superagent': 'npm:superagent/superagent.js',
+            'querystring': 'npm:querystring',
 
             // Fluid Design System
             '@fluid-design-system/core': 
'npm:@fluid-design-system/dist/platform/core/fluid-design-system.module.js',
+            '@fluid-design-system/dialogs': 
'npm:@fluid-design-system/dist/platform/core/dialogs/fds-dialogs.module.js',
+            '@fluid-design-system/dialog-component': 
'npm:@fluid-design-system/dist/platform/core/dialogs/fds-dialog.component.js',
+            '@fluid-design-system/dialog-service': 
'npm:@fluid-design-system/dist/platform/core/dialogs/services/dialog.service.js',
+            '@fluid-design-system/confirm-dialog-component': 
'npm:@fluid-design-system/dist/platform/core/dialogs/confirm-dialog/confirm-dialog.component.js',
         },
         // packages tells the System loader how to load when no filename 
and/or no extension
         packages: {
@@ -68,7 +78,19 @@
             'nifi-registry/systemjs-angular-loader.js': {
                 loader: false
             },
-            rxjs: {
+            'rxjs': {
+                defaultExtension: 'js'
+            },
+            'querystring': {
+                main: './index.js',
+                defaultExtension: 'js'
+            },
+            'moment': {
+                main: './moment.js',
+                defaultExtension: 'js'
+            },
+            'angular2-moment': {
+                main: './index.js',
                 defaultExtension: 'js'
             }
         }

Reply via email to