@blaze-cms/react-page-builder 0.134.0 → 0.135.0-admin-updates.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (169) hide show
  1. package/CHANGELOG.md +26 -0
  2. package/lib/components/Banner/AdSlotRender.js +12 -3
  3. package/lib/components/Banner/AdSlotRender.js.map +1 -1
  4. package/lib/components/Banner/Banner.js +4 -7
  5. package/lib/components/Banner/Banner.js.map +1 -1
  6. package/lib/components/Banner/BannerRender.js +7 -3
  7. package/lib/components/Banner/BannerRender.js.map +1 -1
  8. package/lib/components/Banner/helpers.js +2 -2
  9. package/lib/components/Banner/helpers.js.map +1 -1
  10. package/lib/components/BlazeLink.js +2 -2
  11. package/lib/components/BlazeLink.js.map +1 -1
  12. package/lib/components/Button.js +2 -2
  13. package/lib/components/Button.js.map +1 -1
  14. package/lib/components/Card/CardsContainer.js +2 -2
  15. package/lib/components/Card/CardsContainer.js.map +1 -1
  16. package/lib/components/Card/CardsRender.js +2 -2
  17. package/lib/components/Card/CardsRender.js.map +1 -1
  18. package/lib/components/Card/helpers/filter-query-setup.js +2 -2
  19. package/lib/components/Card/helpers/filter-query-setup.js.map +1 -1
  20. package/lib/components/ClickWrapper.js +2 -2
  21. package/lib/components/ClickWrapper.js.map +1 -1
  22. package/lib/components/Code/Code.js +2 -2
  23. package/lib/components/Code/Code.js.map +1 -1
  24. package/lib/components/DataSummary/helpers/build-loop-props-content.js +3 -2
  25. package/lib/components/DataSummary/helpers/build-loop-props-content.js.map +1 -1
  26. package/lib/components/DataSummary/helpers/get-link-to-published-content.js +2 -0
  27. package/lib/components/DataSummary/helpers/get-link-to-published-content.js.map +1 -1
  28. package/lib/components/Image/Image.js +2 -2
  29. package/lib/components/Image/Image.js.map +1 -1
  30. package/lib/components/Layout/Layout.js +2 -2
  31. package/lib/components/Layout/Layout.js.map +1 -1
  32. package/lib/components/List/ListBuilder.js +2 -2
  33. package/lib/components/List/ListBuilder.js.map +1 -1
  34. package/lib/components/List/ListFactory.js +2 -2
  35. package/lib/components/List/ListFactory.js.map +1 -1
  36. package/lib/components/List/components/Cards/CardsRender.js +2 -2
  37. package/lib/components/List/components/Cards/CardsRender.js.map +1 -1
  38. package/lib/components/List/components/Full/FullRender.js +2 -2
  39. package/lib/components/List/components/Full/FullRender.js.map +1 -1
  40. package/lib/components/List/components/Full/FullRenderItem.js +2 -2
  41. package/lib/components/List/components/Full/FullRenderItem.js.map +1 -1
  42. package/lib/components/List/components/Pagination/ListPagination.js +2 -2
  43. package/lib/components/List/components/Pagination/ListPagination.js.map +1 -1
  44. package/lib/components/List/helpers/build-az-url.js +2 -2
  45. package/lib/components/List/helpers/build-az-url.js.map +1 -1
  46. package/lib/components/List/helpers/build-pagination-url.js +2 -2
  47. package/lib/components/List/helpers/build-pagination-url.js.map +1 -1
  48. package/lib/components/SearchFilter/components/Range.js +2 -2
  49. package/lib/components/SearchFilter/components/Range.js.map +1 -1
  50. package/lib/components/SearchFilter/searchFilterReducer.js +2 -2
  51. package/lib/components/SearchFilterSort/helpers/update-sort.js +2 -2
  52. package/lib/components/SearchFilterSort/helpers/update-sort.js.map +1 -1
  53. package/lib/components/TextBlock/index.js +2 -2
  54. package/lib/components/TextBlock/index.js.map +1 -1
  55. package/lib/components/Video/Video.js +2 -2
  56. package/lib/components/Video/Video.js.map +1 -1
  57. package/lib/components/Video/providers/JWPlayer/JWPlayerProvider.js +2 -2
  58. package/lib/components/Video/providers/JWPlayer/JWPlayerProvider.js.map +1 -1
  59. package/lib/helpers/append-images.js +2 -2
  60. package/lib/helpers/build-raw-query-base.js +2 -2
  61. package/lib/helpers/build-raw-query-base.js.map +1 -1
  62. package/lib/helpers/build-raw-query.js +22 -11
  63. package/lib/helpers/build-raw-query.js.map +1 -1
  64. package/lib/helpers/build-search-values-text.js +8 -5
  65. package/lib/helpers/build-search-values-text.js.map +1 -1
  66. package/lib/helpers/get-banner-data.js +2 -2
  67. package/lib/helpers/get-click-wrapper-options.js +2 -2
  68. package/lib/helpers/get-click-wrapper-options.js.map +1 -1
  69. package/lib/helpers/get-entities-with-banner.js +2 -2
  70. package/lib/helpers/get-entities-with-banner.js.map +1 -1
  71. package/lib/helpers/get-generic-props.js +2 -2
  72. package/lib/helpers/get-generic-props.js.map +1 -1
  73. package/lib/helpers/get-generic-render-variables.js +2 -2
  74. package/lib/helpers/get-generic-render-variables.js.map +1 -1
  75. package/lib/helpers/inject-multiple-banners/get-banners-for-nodes/get-banners-for-nodes.js +2 -2
  76. package/lib/helpers/inject-multiple-banners/get-banners-for-nodes/get-banners-for-nodes.js.map +1 -1
  77. package/lib/helpers/process-data-summary-value.js +2 -2
  78. package/lib/helpers/process-data-summary-value.js.map +1 -1
  79. package/lib/helpers/remove-unwanted-characters.js +2 -2
  80. package/lib/helpers/render-children.js +2 -2
  81. package/lib/helpers/render-children.js.map +1 -1
  82. package/lib/helpers/split-children.js +2 -2
  83. package/lib/helpers/update-childrens-parent.js +2 -2
  84. package/lib/hooks/helpers/append-gtm-classname.js +2 -2
  85. package/lib/hooks/helpers/append-gtm-classname.js.map +1 -1
  86. package/lib/hooks/helpers/buildPBComponents.js +2 -2
  87. package/lib/hooks/helpers/buildPBComponents.js.map +1 -1
  88. package/lib/hooks/helpers/get-lightbox-images.js +2 -2
  89. package/lib/hooks/helpers/get-lightbox-images.js.map +1 -1
  90. package/lib/hooks/helpers/inject-element-banners.js +2 -2
  91. package/lib/hooks/helpers/inject-element-banners.js.map +1 -1
  92. package/lib/hooks/helpers/inject-textblock-banners.js +2 -2
  93. package/lib/hooks/helpers/inject-textblock-banners.js.map +1 -1
  94. package/lib/utils/get-class-modifiers.js +2 -2
  95. package/lib/utils/get-class-modifiers.js.map +1 -1
  96. package/lib-es/components/Banner/AdSlotRender.js +12 -3
  97. package/lib-es/components/Banner/AdSlotRender.js.map +1 -1
  98. package/lib-es/components/Banner/Banner.js +4 -7
  99. package/lib-es/components/Banner/Banner.js.map +1 -1
  100. package/lib-es/components/Banner/BannerRender.js +8 -4
  101. package/lib-es/components/Banner/BannerRender.js.map +1 -1
  102. package/lib-es/components/Banner/helpers.js +2 -2
  103. package/lib-es/components/BlazeLink.js +2 -2
  104. package/lib-es/components/Button.js +2 -2
  105. package/lib-es/components/Card/CardsContainer.js +2 -2
  106. package/lib-es/components/Card/CardsRender.js +2 -2
  107. package/lib-es/components/Card/helpers/filter-query-setup.js +2 -2
  108. package/lib-es/components/ClickWrapper.js +2 -2
  109. package/lib-es/components/Code/Code.js +2 -2
  110. package/lib-es/components/DataSummary/helpers/build-loop-props-content.js +3 -2
  111. package/lib-es/components/DataSummary/helpers/build-loop-props-content.js.map +1 -1
  112. package/lib-es/components/DataSummary/helpers/get-link-to-published-content.js +2 -1
  113. package/lib-es/components/DataSummary/helpers/get-link-to-published-content.js.map +1 -1
  114. package/lib-es/components/Image/Image.js +2 -2
  115. package/lib-es/components/Layout/Layout.js +2 -2
  116. package/lib-es/components/List/ListBuilder.js +2 -2
  117. package/lib-es/components/List/ListFactory.js +2 -2
  118. package/lib-es/components/List/components/Cards/CardsRender.js +2 -2
  119. package/lib-es/components/List/components/Full/FullRender.js +2 -2
  120. package/lib-es/components/List/components/Full/FullRenderItem.js +2 -2
  121. package/lib-es/components/List/components/Pagination/ListPagination.js +2 -2
  122. package/lib-es/components/List/helpers/build-az-url.js +2 -2
  123. package/lib-es/components/List/helpers/build-pagination-url.js +2 -2
  124. package/lib-es/components/SearchFilter/components/Range.js +2 -2
  125. package/lib-es/components/SearchFilter/searchFilterReducer.js +2 -2
  126. package/lib-es/components/SearchFilterSort/helpers/update-sort.js +2 -2
  127. package/lib-es/components/TextBlock/index.js +2 -2
  128. package/lib-es/components/Video/Video.js +2 -2
  129. package/lib-es/components/Video/providers/JWPlayer/JWPlayerProvider.js +2 -2
  130. package/lib-es/helpers/append-images.js +2 -2
  131. package/lib-es/helpers/build-raw-query-base.js +2 -2
  132. package/lib-es/helpers/build-raw-query.js +21 -9
  133. package/lib-es/helpers/build-raw-query.js.map +1 -1
  134. package/lib-es/helpers/build-search-values-text.js +8 -5
  135. package/lib-es/helpers/build-search-values-text.js.map +1 -1
  136. package/lib-es/helpers/get-banner-data.js +2 -2
  137. package/lib-es/helpers/get-click-wrapper-options.js +2 -2
  138. package/lib-es/helpers/get-entities-with-banner.js +2 -2
  139. package/lib-es/helpers/get-generic-props.js +2 -2
  140. package/lib-es/helpers/get-generic-render-variables.js +2 -2
  141. package/lib-es/helpers/inject-multiple-banners/get-banners-for-nodes/get-banners-for-nodes.js +2 -2
  142. package/lib-es/helpers/process-data-summary-value.js +2 -2
  143. package/lib-es/helpers/remove-unwanted-characters.js +2 -2
  144. package/lib-es/helpers/render-children.js +2 -2
  145. package/lib-es/helpers/split-children.js +2 -2
  146. package/lib-es/helpers/update-childrens-parent.js +2 -2
  147. package/lib-es/hooks/helpers/append-gtm-classname.js +2 -2
  148. package/lib-es/hooks/helpers/buildPBComponents.js +2 -2
  149. package/lib-es/hooks/helpers/get-lightbox-images.js +2 -2
  150. package/lib-es/hooks/helpers/inject-element-banners.js +2 -2
  151. package/lib-es/hooks/helpers/inject-textblock-banners.js +2 -2
  152. package/lib-es/utils/get-class-modifiers.js +2 -2
  153. package/package.json +10 -10
  154. package/src/components/Banner/AdSlotRender.js +9 -5
  155. package/src/components/Banner/Banner.js +9 -11
  156. package/src/components/Banner/BannerRender.js +4 -0
  157. package/src/components/DataSummary/helpers/build-loop-props-content.js +3 -2
  158. package/src/components/DataSummary/helpers/get-link-to-published-content.js +4 -1
  159. package/src/helpers/build-raw-query.js +16 -3
  160. package/src/helpers/build-search-values-text.js +20 -17
  161. package/tests/helpers/mocks.js +20 -5
  162. package/tests/unit/src/components/Banner/AdSlotRender.test.js +6 -11
  163. package/tests/unit/src/components/Banner/__snapshots__/AdSlotRender.test.js.snap +45 -25
  164. package/tests/unit/src/components/Banner/__snapshots__/BannerRender.test.js.snap +8 -3
  165. package/tests/unit/src/components/DataSummary/helpers/build-loop-props-content.test.js +41 -0
  166. package/tests/unit/src/components/DataSummary/helpers/get-link-to-published-content.test.js +21 -0
  167. package/tests/unit/src/components/PlaceholderIcon/__snapshots__/index.test.js.snap +87 -0
  168. package/tests/unit/src/components/PlaceholderIcon/index.test.js +20 -0
  169. package/tests/unit/src/helpers/build-search-values-text.test.js +22 -11
@@ -50,17 +50,17 @@ describe('Banner render component', () => {
50
50
  <AdSlotRender {...defaultProps} shouldShowBanner={false} />
51
51
  );
52
52
 
53
- expect(container.childNodes[0].nodeName).toEqual('STYLE');
54
- expect(container.childNodes[1]).toHaveClass('ad-slot ad-slot-loading banner-sizeId');
53
+ expect(container.childNodes[0].nodeName).toEqual('DIV');
54
+ expect(getByTestId('ad-slot')).toHaveClass('ad-slot ad-slot-loading banner-sizeId');
55
55
  expect(() => getByTestId(slotTestId)).toThrow();
56
56
  expect(asFragment()).toMatchSnapshot();
57
57
  });
58
58
 
59
59
  describe('AdSlot loading', () => {
60
60
  it('should render AdSlot', () => {
61
- const { asFragment, container, getByTestId } = render(<AdSlotRender {...defaultProps} />);
61
+ const { asFragment, getByTestId } = render(<AdSlotRender {...defaultProps} />);
62
62
  expect(getByTestId('adslot-test')).toBeDefined();
63
- expect(container.childNodes[1]).toHaveClass('ad-slot ad-slot-loading banner-sizeId');
63
+ expect(getByTestId('ad-slot')).toHaveClass('ad-slot ad-slot-loading banner-sizeId');
64
64
  expect(asFragment()).toMatchSnapshot();
65
65
  });
66
66
 
@@ -69,16 +69,11 @@ describe('Banner render component', () => {
69
69
  const adSlot = getByTestId(slotTestId);
70
70
 
71
71
  fireEvent.mouseOver(adSlot);
72
- await waitFor(() =>
73
- expect(container.childNodes[0]).toHaveClass('ad-slot ad-slot-loaded banner-sizeId')
74
- );
75
- expect(container.childNodes[0]).toHaveStyle('min-height: 250px');
72
+ await waitFor(() => expect(container.childNodes[0]).toHaveClass('banner banner-loaded'));
76
73
  expect(asFragment()).toMatchSnapshot();
77
74
 
78
75
  fireEvent.mouseLeave(adSlot);
79
- await waitFor(() =>
80
- expect(container.childNodes[0]).toHaveClass('ad-slot ad-slot-empty banner-sizeId')
81
- );
76
+ await waitFor(() => expect(container.childNodes[0]).toHaveClass('banner banner-empty'));
82
77
  expect(asFragment()).toMatchSnapshot();
83
78
  });
84
79
  });
@@ -3,13 +3,18 @@
3
3
  exports[`Banner render component AdSlot loading should change class and remove responsive styles after loaded events 1`] = `
4
4
  <DocumentFragment>
5
5
  <div
6
- class="ad-slot ad-slot-loaded banner-sizeId"
7
- style="min-height: 250px;"
6
+ class="banner banner-loaded"
8
7
  >
9
8
  <div
10
- data-testid="adslot-test"
11
- role="button"
12
- />
9
+ class="ad-slot ad-slot-loaded banner-sizeId"
10
+ data-testid="ad-slot"
11
+ style="min-height: 250px;"
12
+ >
13
+ <div
14
+ data-testid="adslot-test"
15
+ role="button"
16
+ />
17
+ </div>
13
18
  </div>
14
19
  </DocumentFragment>
15
20
  `;
@@ -17,44 +22,59 @@ exports[`Banner render component AdSlot loading should change class and remove r
17
22
  exports[`Banner render component AdSlot loading should change class and remove responsive styles after loaded events 2`] = `
18
23
  <DocumentFragment>
19
24
  <div
20
- class="ad-slot ad-slot-empty banner-sizeId"
21
- style=""
25
+ class="banner banner-empty"
22
26
  >
23
27
  <div
24
- data-testid="adslot-test"
25
- role="button"
26
- />
28
+ class="ad-slot ad-slot-empty banner-sizeId"
29
+ data-testid="ad-slot"
30
+ style=""
31
+ >
32
+ <div
33
+ data-testid="adslot-test"
34
+ role="button"
35
+ />
36
+ </div>
27
37
  </div>
28
38
  </DocumentFragment>
29
39
  `;
30
40
 
31
41
  exports[`Banner render component AdSlot loading should render AdSlot 1`] = `
32
42
  <DocumentFragment>
33
- <style>
34
- @media(min-width:320px){.banner-sizeId{min-height:100px;}
35
- @media(min-width:728px){.banner-sizeId{min-height:100px;}
36
- @media(min-width:970px){.banner-sizeId{min-height:250px;}
37
- </style>
38
43
  <div
39
- class="ad-slot ad-slot-loading banner-sizeId"
44
+ class="banner banner-loading"
40
45
  >
46
+ <style>
47
+ @media(min-width:320px){.banner-sizeId{min-height:100px;}
48
+ @media(min-width:728px){.banner-sizeId{min-height:100px;}
49
+ @media(min-width:970px){.banner-sizeId{min-height:250px;}
50
+ </style>
41
51
  <div
42
- data-testid="adslot-test"
43
- role="button"
44
- />
52
+ class="ad-slot ad-slot-loading banner-sizeId"
53
+ data-testid="ad-slot"
54
+ >
55
+ <div
56
+ data-testid="adslot-test"
57
+ role="button"
58
+ />
59
+ </div>
45
60
  </div>
46
61
  </DocumentFragment>
47
62
  `;
48
63
 
49
64
  exports[`Banner render component should not render AdSlot if shouldShowBanner=false but should render styles and wrapper 1`] = `
50
65
  <DocumentFragment>
51
- <style>
52
- @media(min-width:320px){.banner-sizeId{min-height:100px;}
66
+ <div
67
+ class="banner banner-loading"
68
+ >
69
+ <style>
70
+ @media(min-width:320px){.banner-sizeId{min-height:100px;}
53
71
  @media(min-width:728px){.banner-sizeId{min-height:100px;}
54
72
  @media(min-width:970px){.banner-sizeId{min-height:250px;}
55
- </style>
56
- <div
57
- class="ad-slot ad-slot-loading banner-sizeId"
58
- />
73
+ </style>
74
+ <div
75
+ class="ad-slot ad-slot-loading banner-sizeId"
76
+ data-testid="ad-slot"
77
+ />
78
+ </div>
59
79
  </DocumentFragment>
60
80
  `;
@@ -2,9 +2,14 @@
2
2
 
3
3
  exports[`Banner render component should render 1`] = `
4
4
  <DocumentFragment>
5
- <style />
6
5
  <div
7
- class="ad-slot ad-slot-loading banner-sizeId"
8
- />
6
+ class="banner banner-loading"
7
+ >
8
+ <style />
9
+ <div
10
+ class="ad-slot ad-slot-loading banner-sizeId"
11
+ data-testid="ad-slot"
12
+ />
13
+ </div>
9
14
  </DocumentFragment>
10
15
  `;
@@ -90,4 +90,45 @@ describe('buildLoopPropsContent helper function', () => {
90
90
  });
91
91
  expect.hasAssertions();
92
92
  });
93
+
94
+ it('should nested items with urls', () => {
95
+ const data = {
96
+ nestedLoopProp: [
97
+ {
98
+ nestedValue: 'abc',
99
+ url: 'http://blazecms.app/abc'
100
+ },
101
+ {
102
+ nestedValue: '123',
103
+ url: 'http://blazecms.app/123'
104
+ },
105
+ {
106
+ nestedValue: 'no url',
107
+ url: null
108
+ }
109
+ ]
110
+ };
111
+ const withUrl = buildLoopPropsContent(
112
+ mockedLoopProps,
113
+ [
114
+ {
115
+ bold: false,
116
+ enableLink: true,
117
+ label: '',
118
+ modifier: '',
119
+ prefix: '',
120
+ propertiesToDisplay: ['nestedLoopProp.nestedValue'],
121
+ shouldStrip: true
122
+ }
123
+ ],
124
+ 0,
125
+ data
126
+ );
127
+
128
+ withUrl.forEach(([, value, url], index) => {
129
+ expect(value).toEqual(data.nestedLoopProp[index].nestedValue);
130
+ expect(url).toEqual(data.nestedLoopProp[index].url || '');
131
+ });
132
+ expect.hasAssertions();
133
+ });
93
134
  });
@@ -38,4 +38,25 @@ describe('get link to published content', () => {
38
38
  const result = getLinkToPublishedContent(publishedKey, props);
39
39
  expect(result).toEqual('');
40
40
  });
41
+
42
+ it('should return url from the currentValue', () => {
43
+ const currentValue = { url: 'currentValueUrl' };
44
+ const props = { content: [content] };
45
+ const result = getLinkToPublishedContent(publishedKey, props, currentValue);
46
+ expect(result).toEqual(currentValue.url);
47
+ });
48
+
49
+ it('should return url from the currentValue even if falsey', () => {
50
+ const currentValue = { url: null };
51
+ const props = { content: [content] };
52
+ const result = getLinkToPublishedContent(publishedKey, props, currentValue);
53
+ expect(result).toEqual(currentValue.url);
54
+ });
55
+
56
+ it('should not return url from the currentValue if not set', () => {
57
+ const currentValue = {};
58
+ const props = { content: [content] };
59
+ const result = getLinkToPublishedContent(publishedKey, props, currentValue);
60
+ expect(result).toEqual(content.url);
61
+ });
41
62
  });
@@ -0,0 +1,87 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`Placeholder component should render PlaceholderIcon 1`] = `
4
+ <DocumentFragment>
5
+ <div
6
+ class="editor-view__placeholder"
7
+ data-testid="placeholder-icon"
8
+ >
9
+ <svg
10
+ height="25px"
11
+ version="1.1"
12
+ viewBox="0 0 20 20"
13
+ width="25px"
14
+ xmlns="http://www.w3.org/2000/svg"
15
+ xmlns:xlink="http://www.w3.org/1999/xlink"
16
+ >
17
+ <title>
18
+ card
19
+ </title>
20
+ <g
21
+ fill="none"
22
+ fill-rule="evenodd"
23
+ id="Icons"
24
+ stroke="none"
25
+ stroke-width="1"
26
+ >
27
+ <g
28
+ id="card"
29
+ transform="translate(-259, -214)"
30
+ >
31
+ <g
32
+ transform="translate(259, 214)"
33
+ >
34
+ <g
35
+ id="Group-7"
36
+ transform="translate(1, 1)"
37
+ >
38
+ <path
39
+ d="M1.07,10 C3.04212623,8.18723771 4.14171262,7.28085657 4.36875916,7.28085657 C4.79707626,7.28085657 7,9 7.5,9 C8.40867615,9 12.0764465,4.56171314 12.9,4.56171314 C13.4490356,4.56171314 14.8390356,5.81447543 17.07,8.32"
40
+ fill-rule="nonzero"
41
+ id="Path-3"
42
+ stroke="none"
43
+ stroke-width="1.3"
44
+ />
45
+ <path
46
+ d="M5.00003877,4.07973585 C5.00003879,3.4834142 5.50109477,3 6.11917864,3 C6.73726251,3 7.2383185,3.4834142 7.2383185,4.07973585 C7.2383185,4.6760575 6.73726252,5.15947172 6.11917864,5.15947172 C5.82268209,5.15728623 5.53857972,5.04442179 5.32645457,4.84454876 C5.11586241,4.64208328 4.99827309,4.36656405 5.00003877,4.07973585 Z"
47
+ fill="#899BBC"
48
+ fill-rule="nonzero"
49
+ id="Path"
50
+ />
51
+ <path
52
+ d="M3.375,14.625 C3.375,14.3143398 3.62683983,14.0625 3.9375,14.0625 L14.0625,14.0625 C14.3731602,14.0625 14.625,14.3143398 14.625,14.625 C14.625,14.9356602 14.3731602,15.1875 14.0625,15.1875 L3.9375,15.1875 C3.62683983,15.1875 3.375,14.9356602 3.375,14.625 Z"
53
+ fill="#899BBC"
54
+ fill-rule="nonzero"
55
+ id="Shape"
56
+ />
57
+ <rect
58
+ height="16.7"
59
+ id="Rectangle"
60
+ rx="2"
61
+ stroke="#899BBC"
62
+ stroke-width="1.3"
63
+ width="16.7"
64
+ x="0.65"
65
+ y="0.65"
66
+ />
67
+ <line
68
+ id="Line-2"
69
+ stroke="#899BBC"
70
+ stroke-linecap="square"
71
+ stroke-width="1.3"
72
+ x1="1"
73
+ x2="16.5625"
74
+ y1="11.8125"
75
+ y2="11.8125"
76
+ />
77
+ </g>
78
+ </g>
79
+ </g>
80
+ </g>
81
+ </svg>
82
+ <span>
83
+ card
84
+ </span>
85
+ </div>
86
+ </DocumentFragment>
87
+ `;
@@ -0,0 +1,20 @@
1
+ /**
2
+ * @jest-environment jsdom
3
+ */
4
+ import { render } from '@blaze-cms/tools/test-helpers/test-functions';
5
+
6
+ import PlaceholderIcon from '../../../../../../blaze-plugin-page-builder-ui/src/components/EditorView/PlaceholderIcon';
7
+ import { CardIcon } from '../../../../../../blaze-plugin-page-builder-ui/src/Icons';
8
+
9
+ const mockedProps = {
10
+ type: 'card',
11
+ icon: CardIcon
12
+ };
13
+
14
+ describe('Placeholder component', () => {
15
+ it('should render PlaceholderIcon', () => {
16
+ const { asFragment, getByTestId } = render(PlaceholderIcon, mockedProps);
17
+ expect(getByTestId('placeholder-icon')).toBeDefined();
18
+ expect(asFragment()).toMatchSnapshot();
19
+ });
20
+ });
@@ -17,20 +17,31 @@ describe('build search values for text input', () => {
17
17
  const searchValuesNoQueryParams = buildSearchValuesText(textFilter, {});
18
18
 
19
19
  it('should always return an array', () => {
20
- expect(Array.isArray(searchValues)).toEqual(true);
21
- expect(Array.isArray(searchValuesEmpty)).toEqual(true);
20
+ [searchValues, searchValuesEmpty].forEach(searchValue => {
21
+ expect(Array.isArray(searchValues.should)).toEqual(true);
22
+ expect(Array.isArray(searchValues.must)).toEqual(true);
23
+ });
24
+ });
25
+
26
+ it('should have no filters set', () => {
27
+ [searchValues, searchValuesEmpty].forEach(searchValue => {
28
+ expect(searchValuesEmpty.should.length).toEqual(0);
29
+ expect(searchValuesEmpty.must.length).toEqual(0);
30
+ });
22
31
  });
23
32
 
24
33
  it('should return an array with correct data', () => {
25
- const searchArray = [
26
- { match: { pageBuilderIndexed: { query: 'something', fuzziness: 'AUTO' } } },
27
- { match: { name: { query: 'something', fuzziness: 'AUTO' } } },
28
- { match: { metaTitle: { query: 'something', fuzziness: 'AUTO' } } }
29
- ];
34
+ const searchArray = {
35
+ should: [{ match: { pageBuilderIndexed: { query: 'something', fuzziness: 'AUTO' } } }],
36
+ must: [
37
+ { match: { name: { query: 'something', fuzziness: 'AUTO' } } },
38
+ { match: { metaTitle: { query: 'something', fuzziness: 'AUTO' } } }
39
+ ]
40
+ };
30
41
  expect(searchValues).toEqual(searchArray);
31
- expect(searchValuesEmpty).toEqual([]);
32
- expect(searchValues.length).toBe(3);
33
- expect(searchValuesEmpty.length).toBe(0);
34
- expect(searchValuesNoQueryParams.length).toBe(0);
42
+ expect(searchValuesEmpty).toEqual({ should: [], must: [] });
43
+ expect(searchValues.must.length).toBe(2);
44
+ expect(searchValuesEmpty.must.length).toBe(0);
45
+ expect(searchValuesNoQueryParams.must.length).toBe(0);
35
46
  });
36
47
  });