Commit 6574dcf055f5adb0497fb10d7b92fdc563cd0b30

Authored by Leandro Santos
2 parents e61ba345 ab814829

Merge branch 'hide-empty-block' into 'master'

Hide empty blocks

Depends on !19

See merge request !23
src/app/layout/boxes/display-blocks.filter.spec.ts
@@ -82,5 +82,19 @@ describe("Filters", () => { @@ -82,5 +82,19 @@ describe("Filters", () => {
82 expect(filter.transform(<any>blocks, true, <noosfero.User>{})).toEqual([]); 82 expect(filter.transform(<any>blocks, true, <noosfero.User>{})).toEqual([]);
83 done(); 83 done();
84 }); 84 });
  85 +
  86 + it("filter blocks when hide is true", done => {
  87 + let blocks = [{ hide: true }];
  88 + let filter = new DisplayBlocks(translatorService);
  89 + expect(filter.transform(<any>blocks, true, null)).toEqual([]);
  90 + done();
  91 + });
  92 +
  93 + it("not filter blocks when hide is not true", done => {
  94 + let blocks = [{ id: 1, hide: false }, { id: 2 }];
  95 + let filter = new DisplayBlocks(translatorService);
  96 + expect(filter.transform(<any>blocks, true, null)).toEqual(blocks);
  97 + done();
  98 + });
85 }); 99 });
86 }); 100 });
src/app/layout/boxes/display-blocks.filter.ts
@@ -12,7 +12,8 @@ export class DisplayBlocks { @@ -12,7 +12,8 @@ export class DisplayBlocks {
12 blocks = blocks || []; 12 blocks = blocks || [];
13 for (let block of blocks) { 13 for (let block of blocks) {
14 if (this.visible(block, isHomepage) && this.displayToUser(block, currentUser) && 14 if (this.visible(block, isHomepage) && this.displayToUser(block, currentUser) &&
15 - this.displayOnLanguage(block, this.translatorService.currentLanguage())) { 15 + this.displayOnLanguage(block, this.translatorService.currentLanguage())
  16 + && !block.hide) {
16 selected.push(block); 17 selected.push(block);
17 } 18 }
18 } 19 }
src/lib/ng-noosfero-api/interfaces/block.ts
@@ -4,5 +4,6 @@ namespace noosfero { @@ -4,5 +4,6 @@ namespace noosfero {
4 settings: Settings; 4 settings: Settings;
5 limit: number; 5 limit: number;
6 api_content: any; 6 api_content: any;
  7 + hide: boolean;
7 } 8 }
8 } 9 }
src/plugins/comment_paragraph/block/discussion/discussion-block.component.spec.ts
@@ -14,7 +14,7 @@ describe(&quot;Components&quot;, () =&gt; { @@ -14,7 +14,7 @@ describe(&quot;Components&quot;, () =&gt; {
14 let helper: ComponentTestHelper<DiscussionBlockComponent>; 14 let helper: ComponentTestHelper<DiscussionBlockComponent>;
15 let settingsObj = {}; 15 let settingsObj = {};
16 let mockedBlockService = { 16 let mockedBlockService = {
17 - getApiContent: (block: noosfero.Block): any => { 17 + getApiContent: (content: any): any => {
18 return Promise.resolve({ articles: [{ name: "article1" }], headers: (name: string) => { return name; } }); 18 return Promise.resolve({ articles: [{ name: "article1" }], headers: (name: string) => { return name; } });
19 } 19 }
20 }; 20 };
@@ -36,13 +36,14 @@ describe(&quot;Components&quot;, () =&gt; { @@ -36,13 +36,14 @@ describe(&quot;Components&quot;, () =&gt; {
36 template: htmlTemplate, 36 template: htmlTemplate,
37 directives: [DiscussionBlockComponent], 37 directives: [DiscussionBlockComponent],
38 providers: providers, 38 providers: providers,
39 - properties: {} 39 + properties: { block: {} }
40 }); 40 });
41 helper = new ComponentTestHelper<DiscussionBlockComponent>(cls, done); 41 helper = new ComponentTestHelper<DiscussionBlockComponent>(cls, done);
42 }); 42 });
43 43
44 it("get discussions from the block service", () => { 44 it("get discussions from the block service", () => {
45 expect(helper.component.documents).toEqual([{ name: "article1" }]); 45 expect(helper.component.documents).toEqual([{ name: "article1" }]);
  46 + expect(helper.component.block.hide).toEqual(false);
46 }); 47 });
47 48
48 it("go to article page when open a document", () => { 49 it("go to article page when open a document", () => {
src/plugins/comment_paragraph/block/discussion/discussion-block.component.ts
@@ -20,6 +20,7 @@ export class DiscussionBlockComponent { @@ -20,6 +20,7 @@ export class DiscussionBlockComponent {
20 this.profile = this.owner; 20 this.profile = this.owner;
21 this.blockService.getApiContent(this.block).then((content: any) => { 21 this.blockService.getApiContent(this.block).then((content: any) => {
22 this.documents = content.articles; 22 this.documents = content.articles;
  23 + this.block.hide = !this.documents || this.documents.length === 0;
23 }); 24 });
24 } 25 }
25 26