@skyux/layout 7.0.0-beta.0 → 7.0.0-beta.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 (92) hide show
  1. package/documentation.json +1679 -990
  2. package/esm2020/index.mjs +1 -2
  3. package/esm2020/lib/modules/action-button/action-button-adapter-service.mjs +22 -18
  4. package/esm2020/lib/modules/action-button/action-button-container.component.mjs +62 -54
  5. package/esm2020/lib/modules/action-button/action-button-icon.component.mjs +9 -6
  6. package/esm2020/lib/modules/action-button/action-button.component.mjs +10 -6
  7. package/esm2020/lib/modules/back-to-top/back-to-top-adapter.service.mjs +19 -15
  8. package/esm2020/lib/modules/back-to-top/back-to-top.component.mjs +8 -5
  9. package/esm2020/lib/modules/back-to-top/back-to-top.directive.mjs +68 -63
  10. package/esm2020/lib/modules/box/box.component.mjs +1 -1
  11. package/esm2020/lib/modules/card/card.component.mjs +38 -11
  12. package/esm2020/lib/modules/definition-list/definition-list-label.component.mjs +1 -1
  13. package/esm2020/lib/modules/definition-list/definition-list-value.component.mjs +3 -3
  14. package/esm2020/lib/modules/definition-list/definition-list.component.mjs +1 -1
  15. package/esm2020/lib/modules/definition-list/definition-list.service.mjs +1 -1
  16. package/esm2020/lib/modules/description-list/description-list-adapter-service.mjs +26 -22
  17. package/esm2020/lib/modules/description-list/description-list-content.component.mjs +2 -2
  18. package/esm2020/lib/modules/description-list/description-list-description.component.mjs +16 -11
  19. package/esm2020/lib/modules/description-list/description-list-term.component.mjs +1 -1
  20. package/esm2020/lib/modules/description-list/description-list.component.mjs +25 -16
  21. package/esm2020/lib/modules/fluid-grid/column.component.mjs +19 -1
  22. package/esm2020/lib/modules/fluid-grid/fluid-grid.component.mjs +15 -35
  23. package/esm2020/lib/modules/fluid-grid/row.component.mjs +1 -1
  24. package/esm2020/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.mjs +1 -1
  25. package/esm2020/lib/modules/format/format.component.mjs +34 -26
  26. package/esm2020/lib/modules/inline-delete/inline-delete-adapter.service.mjs +91 -83
  27. package/esm2020/lib/modules/inline-delete/inline-delete.component.mjs +15 -9
  28. package/esm2020/lib/modules/page/page-theme-adapter.service.mjs +14 -8
  29. package/esm2020/lib/modules/page/page.component.mjs +8 -4
  30. package/esm2020/lib/modules/page-summary/page-summary-adapter.service.mjs +1 -1
  31. package/esm2020/lib/modules/page-summary/page-summary.component.mjs +40 -16
  32. package/esm2020/lib/modules/text-expand/text-expand-adapter.service.mjs +8 -10
  33. package/esm2020/lib/modules/text-expand/text-expand-modal-context-token.mjs +6 -0
  34. package/esm2020/lib/modules/text-expand/text-expand-modal-context.mjs +2 -6
  35. package/esm2020/lib/modules/text-expand/text-expand-modal.component.mjs +12 -10
  36. package/esm2020/lib/modules/text-expand/text-expand.component.mjs +188 -127
  37. package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.mjs +10 -12
  38. package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater.component.mjs +139 -95
  39. package/esm2020/lib/modules/toolbar/toolbar.component.mjs +4 -4
  40. package/esm2020/testing/action-button-fixture.mjs +12 -6
  41. package/esm2020/testing/card-fixture.mjs +19 -16
  42. package/esm2020/testing/page-summary-fixture.mjs +9 -5
  43. package/fesm2015/skyux-layout-testing.mjs +35 -24
  44. package/fesm2015/skyux-layout-testing.mjs.map +1 -1
  45. package/fesm2015/skyux-layout.mjs +866 -673
  46. package/fesm2015/skyux-layout.mjs.map +1 -1
  47. package/fesm2020/skyux-layout-testing.mjs +35 -24
  48. package/fesm2020/skyux-layout-testing.mjs.map +1 -1
  49. package/fesm2020/skyux-layout.mjs +861 -673
  50. package/fesm2020/skyux-layout.mjs.map +1 -1
  51. package/index.d.ts +0 -1
  52. package/lib/modules/action-button/action-button-adapter-service.d.ts +1 -2
  53. package/lib/modules/action-button/action-button-container.component.d.ts +6 -17
  54. package/lib/modules/action-button/action-button-icon.component.d.ts +2 -3
  55. package/lib/modules/action-button/action-button.component.d.ts +3 -3
  56. package/lib/modules/back-to-top/back-to-top-adapter.service.d.ts +1 -4
  57. package/lib/modules/back-to-top/back-to-top.component.d.ts +1 -1
  58. package/lib/modules/back-to-top/back-to-top.directive.d.ts +4 -16
  59. package/lib/modules/box/box.component.d.ts +3 -3
  60. package/lib/modules/card/card.component.d.ts +7 -6
  61. package/lib/modules/definition-list/definition-list-label.component.d.ts +1 -1
  62. package/lib/modules/definition-list/definition-list-value.component.d.ts +1 -1
  63. package/lib/modules/definition-list/definition-list.component.d.ts +2 -2
  64. package/lib/modules/definition-list/definition-list.service.d.ts +2 -2
  65. package/lib/modules/description-list/description-list-adapter-service.d.ts +1 -2
  66. package/lib/modules/description-list/description-list-content.component.d.ts +2 -2
  67. package/lib/modules/description-list/description-list-description.component.d.ts +5 -7
  68. package/lib/modules/description-list/description-list-term.component.d.ts +1 -1
  69. package/lib/modules/description-list/description-list.component.d.ts +6 -7
  70. package/lib/modules/fluid-grid/column.component.d.ts +7 -5
  71. package/lib/modules/fluid-grid/fluid-grid.component.d.ts +3 -9
  72. package/lib/modules/fluid-grid/row.component.d.ts +1 -1
  73. package/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.d.ts +1 -1
  74. package/lib/modules/format/format.component.d.ts +5 -7
  75. package/lib/modules/inline-delete/inline-delete-adapter.service.d.ts +1 -11
  76. package/lib/modules/inline-delete/inline-delete.component.d.ts +3 -5
  77. package/lib/modules/page/page-theme-adapter.service.d.ts +1 -1
  78. package/lib/modules/page/page.component.d.ts +1 -1
  79. package/lib/modules/page-summary/page-summary.component.d.ts +8 -9
  80. package/lib/modules/text-expand/text-expand-adapter.service.d.ts +3 -4
  81. package/lib/modules/text-expand/text-expand-modal-context-token.d.ts +6 -0
  82. package/lib/modules/text-expand/text-expand-modal-context.d.ts +1 -1
  83. package/lib/modules/text-expand/text-expand.component.d.ts +18 -25
  84. package/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.d.ts +4 -5
  85. package/lib/modules/text-expand-repeater/text-expand-repeater.component.d.ts +13 -21
  86. package/lib/modules/toolbar/toolbar.component.d.ts +4 -4
  87. package/package.json +9 -9
  88. package/testing/action-button-fixture.d.ts +4 -4
  89. package/testing/card-fixture.d.ts +3 -5
  90. package/testing/page-summary-fixture.d.ts +4 -4
  91. package/esm2020/lib/modules/fluid-grid/fluid-grid-gutter-size.mjs +0 -20
  92. package/lib/modules/fluid-grid/fluid-grid-gutter-size.d.ts +0 -18
@@ -1,10 +1,13 @@
1
+ var _SkyTextExpandComponent_instances, _SkyTextExpandComponent_collapsedText, _SkyTextExpandComponent_newlineCount, _SkyTextExpandComponent_seeMoreText, _SkyTextExpandComponent_seeLessText, _SkyTextExpandComponent_textToShow, _SkyTextExpandComponent__maxExpandedLength, _SkyTextExpandComponent__maxExpandedNewlines, _SkyTextExpandComponent__maxLength, _SkyTextExpandComponent__text, _SkyTextExpandComponent__textEl, _SkyTextExpandComponent_resources, _SkyTextExpandComponent_modalSvc, _SkyTextExpandComponent_textExpandAdapter, _SkyTextExpandComponent_setup, _SkyTextExpandComponent_getNewlineCount, _SkyTextExpandComponent_getTruncatedText, _SkyTextExpandComponent_animateText;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
+ import { animate, state, style, transition, trigger, } from '@angular/animations';
1
4
  import { Component, ElementRef, Input, ViewChild, } from '@angular/core';
2
5
  import { SkyLibResourcesService } from '@skyux/i18n';
3
6
  import { SkyModalService } from '@skyux/modals';
4
7
  import { forkJoin as observableForkJoin } from 'rxjs';
5
8
  import { take } from 'rxjs/operators';
6
9
  import { SkyTextExpandAdapterService } from './text-expand-adapter.service';
7
- import { SkyTextExpandModalContext } from './text-expand-modal-context';
10
+ import { SKY_TEXT_EXPAND_MODAL_CONTEXT } from './text-expand-modal-context-token';
8
11
  import { SkyTextExpandModalComponent } from './text-expand-modal.component';
9
12
  import * as i0 from "@angular/core";
10
13
  import * as i1 from "@skyux/i18n";
@@ -16,29 +19,69 @@ import * as i4 from "@angular/common";
16
19
  */
17
20
  let nextId = 0;
18
21
  export class SkyTextExpandComponent {
19
- constructor(resources, modalService, textExpandAdapter) {
20
- this.resources = resources;
21
- this.modalService = modalService;
22
- this.textExpandAdapter = textExpandAdapter;
23
- /**
24
- * Specifies the maximum number of text characters to display inline when users select the link
25
- * to expand the full text. If the text exceeds this limit, then the component expands
26
- * the full text in a modal instead.
27
- */
28
- this.maxExpandedLength = 600;
29
- /**
30
- * Specifies the maximum number of newline characters to display inline when users select
31
- * the link to expand the full text. If the text exceeds this limit, then
32
- * the component expands the full text in a modal view instead.
33
- */
34
- this.maxExpandedNewlines = 2;
22
+ constructor(resources, modalSvc, textExpandAdapter) {
23
+ _SkyTextExpandComponent_instances.add(this);
35
24
  /**
36
25
  * Indicates whether to replace newline characters in truncated text with spaces.
37
26
  */
38
27
  this.truncateNewlines = true;
28
+ this.buttonText = '';
39
29
  this.contentSectionId = `sky-text-expand-content-${++nextId}`;
40
- this.isExpanded = false;
41
- this._maxLength = 200;
30
+ this.expandable = false;
31
+ this.isModal = false;
32
+ this.transitionHeight = 1;
33
+ _SkyTextExpandComponent_collapsedText.set(this, '');
34
+ _SkyTextExpandComponent_newlineCount.set(this, 0);
35
+ _SkyTextExpandComponent_seeMoreText.set(this, '');
36
+ _SkyTextExpandComponent_seeLessText.set(this, '');
37
+ _SkyTextExpandComponent_textToShow.set(this, '');
38
+ _SkyTextExpandComponent__maxExpandedLength.set(this, 600);
39
+ _SkyTextExpandComponent__maxExpandedNewlines.set(this, 2);
40
+ _SkyTextExpandComponent__maxLength.set(this, 200);
41
+ _SkyTextExpandComponent__text.set(this, '');
42
+ _SkyTextExpandComponent__textEl.set(this, void 0);
43
+ _SkyTextExpandComponent_resources.set(this, void 0);
44
+ _SkyTextExpandComponent_modalSvc.set(this, void 0);
45
+ _SkyTextExpandComponent_textExpandAdapter.set(this, void 0);
46
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_resources, resources, "f");
47
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_modalSvc, modalSvc, "f");
48
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_textExpandAdapter, textExpandAdapter, "f");
49
+ }
50
+ /**
51
+ * Specifies the maximum number of text characters to display inline when users select the link
52
+ * to expand the full text. If the text exceeds this limit, then the component expands
53
+ * the full text in a modal instead.
54
+ * @default 600
55
+ */
56
+ set maxExpandedLength(value) {
57
+ if (value) {
58
+ __classPrivateFieldSet(this, _SkyTextExpandComponent__maxExpandedLength, value, "f");
59
+ }
60
+ else {
61
+ __classPrivateFieldSet(this, _SkyTextExpandComponent__maxExpandedLength, 600, "f");
62
+ }
63
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_instances, "m", _SkyTextExpandComponent_setup).call(this, this.text);
64
+ }
65
+ get maxExpandedLength() {
66
+ return __classPrivateFieldGet(this, _SkyTextExpandComponent__maxExpandedLength, "f");
67
+ }
68
+ /**
69
+ * Specifies the maximum number of newline characters to display inline when users select
70
+ * the link to expand the full text. If the text exceeds this limit, then
71
+ * the component expands the full text in a modal view instead.
72
+ * @default 2
73
+ */
74
+ set maxExpandedNewlines(value) {
75
+ if (value) {
76
+ __classPrivateFieldSet(this, _SkyTextExpandComponent__maxExpandedNewlines, value, "f");
77
+ }
78
+ else {
79
+ __classPrivateFieldSet(this, _SkyTextExpandComponent__maxExpandedNewlines, 2, "f");
80
+ }
81
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_instances, "m", _SkyTextExpandComponent_setup).call(this, this.text);
82
+ }
83
+ get maxExpandedNewlines() {
84
+ return __classPrivateFieldGet(this, _SkyTextExpandComponent__maxExpandedNewlines, "f");
42
85
  }
43
86
  /**
44
87
  * Specifies the number of text characters to display before truncating the text.
@@ -47,23 +90,33 @@ export class SkyTextExpandComponent {
47
90
  * @default 200
48
91
  */
49
92
  set maxLength(value) {
50
- this._maxLength = value;
51
- /* istanbul ignore else */
52
- if (this.textEl) {
53
- this.setup(this.expandedText);
93
+ if (value) {
94
+ __classPrivateFieldSet(this, _SkyTextExpandComponent__maxLength, value, "f");
54
95
  }
96
+ else {
97
+ __classPrivateFieldSet(this, _SkyTextExpandComponent__maxLength, 200, "f");
98
+ }
99
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_instances, "m", _SkyTextExpandComponent_setup).call(this, this.text);
55
100
  }
56
101
  get maxLength() {
57
- return this._maxLength;
102
+ return __classPrivateFieldGet(this, _SkyTextExpandComponent__maxLength, "f");
58
103
  }
59
104
  /**
60
105
  * Specifies the text to truncate.
61
106
  */
62
107
  set text(value) {
63
- /* istanbul ignore else */
64
- if (this.textEl) {
65
- this.setup(value);
66
- }
108
+ __classPrivateFieldSet(this, _SkyTextExpandComponent__text, value ?? '', "f");
109
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_instances, "m", _SkyTextExpandComponent_setup).call(this, __classPrivateFieldGet(this, _SkyTextExpandComponent__text, "f"));
110
+ }
111
+ get text() {
112
+ return __classPrivateFieldGet(this, _SkyTextExpandComponent__text, "f");
113
+ }
114
+ set textEl(value) {
115
+ __classPrivateFieldSet(this, _SkyTextExpandComponent__textEl, value, "f");
116
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_instances, "m", _SkyTextExpandComponent_setup).call(this, this.text);
117
+ }
118
+ get textEl() {
119
+ return __classPrivateFieldGet(this, _SkyTextExpandComponent__textEl, "f");
67
120
  }
68
121
  textExpand() {
69
122
  if (this.isModal) {
@@ -71,12 +124,12 @@ export class SkyTextExpandComponent {
71
124
  /* istanbul ignore else */
72
125
  /* sanity check */
73
126
  if (!this.isExpanded) {
74
- this.modalService.open(SkyTextExpandModalComponent, [
127
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_modalSvc, "f").open(SkyTextExpandModalComponent, [
75
128
  {
76
- provide: SkyTextExpandModalContext,
129
+ provide: SKY_TEXT_EXPAND_MODAL_CONTEXT,
77
130
  useValue: {
78
131
  header: this.expandModalTitle,
79
- text: this.expandedText,
132
+ text: this.text,
80
133
  },
81
134
  },
82
135
  ]);
@@ -85,40 +138,38 @@ export class SkyTextExpandComponent {
85
138
  else {
86
139
  // Normal View
87
140
  if (!this.isExpanded) {
88
- this.setContainerMaxHeight();
89
- setTimeout(() => {
90
- this.isExpanded = true;
91
- this.animateText(this.collapsedText, this.expandedText, true);
92
- }, 10);
141
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_instances, "m", _SkyTextExpandComponent_animateText).call(this, true);
93
142
  }
94
143
  else {
95
- this.setContainerMaxHeight();
96
- setTimeout(() => {
97
- this.isExpanded = false;
98
- this.animateText(this.expandedText, this.collapsedText, false);
99
- }, 10);
144
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_instances, "m", _SkyTextExpandComponent_animateText).call(this, false);
100
145
  }
101
146
  }
102
147
  }
103
148
  animationEnd() {
104
- // Ensure the correct text is displayed
105
- this.textExpandAdapter.setText(this.textEl, this.textToShow);
106
- // Set height back to auto so the browser can change the height as needed with window changes
107
- this.textExpandAdapter.setContainerHeight(this.containerEl, undefined);
149
+ if (this.textEl && this.containerEl) {
150
+ // Ensure the correct text is displayed
151
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_textExpandAdapter, "f").setText(this.textEl, __classPrivateFieldGet(this, _SkyTextExpandComponent_textToShow, "f"));
152
+ setTimeout(() => {
153
+ if (this.containerEl) {
154
+ // Set height back to auto so the browser can change the height as needed with window changes
155
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_textExpandAdapter, "f").removeContainerMaxHeight(this.containerEl);
156
+ }
157
+ });
158
+ }
108
159
  }
109
160
  ngAfterContentInit() {
110
161
  observableForkJoin([
111
- this.resources.getString('skyux_text_expand_see_more'),
112
- this.resources.getString('skyux_text_expand_see_less'),
162
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_resources, "f").getString('skyux_text_expand_see_more'),
163
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_resources, "f").getString('skyux_text_expand_see_less'),
113
164
  ])
114
165
  .pipe(take(1))
115
166
  .subscribe((resources) => {
116
- this.seeMoreText = resources[0];
117
- this.seeLessText = resources[1];
118
- this.setup(this.expandedText);
167
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_seeMoreText, resources[0], "f");
168
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_seeLessText, resources[1], "f");
169
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_instances, "m", _SkyTextExpandComponent_setup).call(this, this.text);
119
170
  /* istanbul ignore else */
120
171
  if (!this.expandModalTitle) {
121
- this.resources
172
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_resources, "f")
122
173
  .getString('skyux_text_expand_modal_title')
123
174
  .pipe(take(1))
124
175
  .subscribe((resource) => {
@@ -127,98 +178,108 @@ export class SkyTextExpandComponent {
127
178
  }
128
179
  });
129
180
  }
130
- setContainerMaxHeight() {
131
- // ensure everything is reset
132
- this.animationEnd();
133
- /* Before animation is kicked off, ensure that a maxHeight exists */
134
- /* Once we have support for angular v4 animations with parameters we can use that instead */
135
- const currentHeight = this.textExpandAdapter.getContainerHeight(this.containerEl);
136
- this.textExpandAdapter.setContainerHeight(this.containerEl, `${currentHeight}px`);
137
- }
138
- setup(value) {
139
- if (value) {
140
- this.newlineCount = this.getNewlineCount(value);
141
- this.collapsedText = this.getTruncatedText(value, this.maxLength);
142
- this.expandedText = value;
143
- if (this.collapsedText !== value) {
144
- this.buttonText = this.seeMoreText;
145
- this.isExpanded = false;
146
- this.expandable = true;
147
- this.isModal =
148
- this.newlineCount > this.maxExpandedNewlines ||
149
- this.expandedText.length > this.maxExpandedLength;
150
- }
151
- else {
152
- this.expandable = false;
153
- }
154
- this.textToShow = this.collapsedText;
181
+ }
182
+ _SkyTextExpandComponent_collapsedText = new WeakMap(), _SkyTextExpandComponent_newlineCount = new WeakMap(), _SkyTextExpandComponent_seeMoreText = new WeakMap(), _SkyTextExpandComponent_seeLessText = new WeakMap(), _SkyTextExpandComponent_textToShow = new WeakMap(), _SkyTextExpandComponent__maxExpandedLength = new WeakMap(), _SkyTextExpandComponent__maxExpandedNewlines = new WeakMap(), _SkyTextExpandComponent__maxLength = new WeakMap(), _SkyTextExpandComponent__text = new WeakMap(), _SkyTextExpandComponent__textEl = new WeakMap(), _SkyTextExpandComponent_resources = new WeakMap(), _SkyTextExpandComponent_modalSvc = new WeakMap(), _SkyTextExpandComponent_textExpandAdapter = new WeakMap(), _SkyTextExpandComponent_instances = new WeakSet(), _SkyTextExpandComponent_setup = function _SkyTextExpandComponent_setup(value) {
183
+ if (value) {
184
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_newlineCount, __classPrivateFieldGet(this, _SkyTextExpandComponent_instances, "m", _SkyTextExpandComponent_getNewlineCount).call(this, value), "f");
185
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_collapsedText, __classPrivateFieldGet(this, _SkyTextExpandComponent_instances, "m", _SkyTextExpandComponent_getTruncatedText).call(this, value, this.maxLength), "f");
186
+ if (__classPrivateFieldGet(this, _SkyTextExpandComponent_collapsedText, "f") !== value) {
187
+ this.buttonText = __classPrivateFieldGet(this, _SkyTextExpandComponent_seeMoreText, "f");
188
+ this.isExpanded = false;
189
+ this.expandable = true;
190
+ this.isModal =
191
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_newlineCount, "f") > this.maxExpandedNewlines ||
192
+ this.text.length > this.maxExpandedLength;
155
193
  }
156
194
  else {
157
- this.textToShow = '';
158
195
  this.expandable = false;
159
196
  }
160
- this.textExpandAdapter.setText(this.textEl, this.textToShow);
197
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_textToShow, __classPrivateFieldGet(this, _SkyTextExpandComponent_collapsedText, "f"), "f");
161
198
  }
162
- getNewlineCount(value) {
163
- const matches = value.match(/\n/gi);
164
- if (matches) {
165
- return matches.length;
166
- }
167
- return 0;
199
+ else {
200
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_textToShow, '', "f");
201
+ this.expandable = false;
168
202
  }
169
- getTruncatedText(value, length) {
170
- let i;
171
- if (this.truncateNewlines) {
172
- value = value.replace(/\n+/gi, ' ');
173
- }
174
- // Jump ahead one character and see if it's a space, and if it isn't,
175
- // back up to the first space and break there so a word doesn't get cut
176
- // in half.
177
- if (length < value.length) {
178
- for (i = length; i > length - 10; i--) {
179
- if (/\s/.test(value.charAt(i))) {
180
- length = i;
181
- break;
182
- }
203
+ if (this.textEl) {
204
+ __classPrivateFieldGet(this, _SkyTextExpandComponent_textExpandAdapter, "f").setText(this.textEl, __classPrivateFieldGet(this, _SkyTextExpandComponent_textToShow, "f"));
205
+ }
206
+ }, _SkyTextExpandComponent_getNewlineCount = function _SkyTextExpandComponent_getNewlineCount(value) {
207
+ const matches = value.match(/\n/gi);
208
+ if (matches) {
209
+ return matches.length;
210
+ }
211
+ return 0;
212
+ }, _SkyTextExpandComponent_getTruncatedText = function _SkyTextExpandComponent_getTruncatedText(value, length) {
213
+ let i;
214
+ if (this.truncateNewlines) {
215
+ value = value.replace(/\n+/gi, ' ');
216
+ }
217
+ // Jump ahead one character and see if it's a space, and if it isn't,
218
+ // back up to the first space and break there so a word doesn't get cut
219
+ // in half.
220
+ if (length < value.length) {
221
+ for (i = length; i > length - 10; i--) {
222
+ if (/\s/.test(value.charAt(i))) {
223
+ length = i;
224
+ break;
183
225
  }
184
226
  }
185
- return value.substr(0, length);
186
227
  }
187
- animateText(previousText, newText, expanding) {
188
- const adapter = this.textExpandAdapter;
228
+ return value.substring(0, length);
229
+ }, _SkyTextExpandComponent_animateText = function _SkyTextExpandComponent_animateText(expanding) {
230
+ if (this.containerEl && this.textEl) {
231
+ const adapter = __classPrivateFieldGet(this, _SkyTextExpandComponent_textExpandAdapter, "f");
189
232
  const container = this.containerEl;
190
- // Reset max height
191
- adapter.setContainerHeight(container, undefined);
192
- // Measure the current height so we can animate from it.
193
- const currentHeight = adapter.getContainerHeight(container);
194
- this.textToShow = newText;
195
- adapter.setText(this.textEl, this.textToShow);
196
- this.buttonText = expanding ? this.seeLessText : this.seeMoreText;
233
+ if (expanding) {
234
+ adapter.setText(this.textEl, this.text);
235
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_textToShow, this.text, "f");
236
+ }
237
+ else {
238
+ adapter.setText(this.textEl, __classPrivateFieldGet(this, _SkyTextExpandComponent_collapsedText, "f"));
239
+ __classPrivateFieldSet(this, _SkyTextExpandComponent_textToShow, __classPrivateFieldGet(this, _SkyTextExpandComponent_collapsedText, "f"), "f");
240
+ }
241
+ this.buttonText = expanding ? __classPrivateFieldGet(this, _SkyTextExpandComponent_seeLessText, "f") : __classPrivateFieldGet(this, _SkyTextExpandComponent_seeMoreText, "f");
197
242
  // Measure the new height so we can animate to it.
198
243
  const newHeight = adapter.getContainerHeight(container);
199
- /* istanbul ignore if */
200
- if (newHeight < currentHeight) {
201
- // The new text is smaller than the old text, so put the old text back before doing
202
- // the collapse animation to avoid showing a big chunk of whitespace.
203
- adapter.setText(this.textEl, previousText);
244
+ this.transitionHeight = newHeight;
245
+ // Always show all text while animating so that the animation is smooth. The animation callback will set this back if needed.
246
+ if (!expanding) {
247
+ adapter.setText(this.textEl, this.text);
204
248
  }
205
- adapter.setContainerHeight(container, `${currentHeight}px`);
206
- // This timeout is necessary due to the browser needing to pick up the non-auto height being set
207
- // in order to do the transtion in height correctly. Without it the transition does not fire.
208
- setTimeout(() => {
209
- adapter.setContainerHeight(container, `${newHeight}px`);
210
- /* This resets values if the transition does not get kicked off */
211
- setTimeout(() => {
212
- this.animationEnd();
213
- }, 500);
214
- }, 10);
249
+ this.isExpanded = expanding;
215
250
  }
216
- }
251
+ };
217
252
  SkyTextExpandComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTextExpandComponent, deps: [{ token: i1.SkyLibResourcesService }, { token: i2.SkyModalService }, { token: i3.SkyTextExpandAdapterService }], target: i0.ɵɵFactoryTarget.Component });
218
- SkyTextExpandComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyTextExpandComponent, selector: "sky-text-expand", inputs: { expandModalTitle: "expandModalTitle", maxExpandedLength: "maxExpandedLength", maxExpandedNewlines: "maxExpandedNewlines", maxLength: "maxLength", text: "text", truncateNewlines: "truncateNewlines" }, providers: [SkyTextExpandAdapterService], viewQueries: [{ propertyName: "containerEl", first: true, predicate: ["container"], descendants: true, read: ElementRef, static: true }, { propertyName: "textEl", first: true, predicate: ["text"], descendants: true, read: ElementRef, static: true }], ngImport: i0, template: "<div\n class=\"sky-text-expand-container\"\n (transitionend)=\"animationEnd()\"\n #container\n>\n <span class=\"sky-text-expand-text\" [id]=\"contentSectionId\" #text></span>\n <span class=\"sky-text-expand-ellipsis\" *ngIf=\"!isExpanded && expandable\"\n >...\n </span>\n <button\n *ngIf=\"expandable\"\n type=\"button\"\n class=\"sky-btn sky-btn-link-inline sky-text-expand-see-more\"\n [attr.aria-expanded]=\"isModal ? undefined : isExpanded\"\n [attr.aria-controls]=\"isModal ? undefined : contentSectionId\"\n [attr.aria-haspopup]=\"isModal ? 'dialog' : undefined\"\n (click)=\"textExpand()\"\n >\n {{ buttonText }}\n </button>\n</div>\n", styles: [".sky-text-expand-ellipsis{letter-spacing:2px;white-space:nowrap}.sky-text-expand-space{white-space:normal}.sky-text-expand-see-more{white-space:nowrap;margin-left:5px}.sky-text-expand-text{margin:0;white-space:pre-wrap}.sky-text-expand-container{word-break:break-word;word-wrap:break-word;overflow:hidden;height:auto;transition:max-height .25s}.sky-text-expand-modal-content{white-space:pre-line;word-wrap:break-word}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
253
+ SkyTextExpandComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyTextExpandComponent, selector: "sky-text-expand", inputs: { expandModalTitle: "expandModalTitle", maxExpandedLength: "maxExpandedLength", maxExpandedNewlines: "maxExpandedNewlines", maxLength: "maxLength", text: "text", truncateNewlines: "truncateNewlines" }, providers: [SkyTextExpandAdapterService], viewQueries: [{ propertyName: "containerEl", first: true, predicate: ["container"], descendants: true, read: ElementRef, static: true }, { propertyName: "textEl", first: true, predicate: ["text"], descendants: true, read: ElementRef, static: true }], ngImport: i0, template: "<div\n [@expansionAnimation]=\"{\n value: isExpanded,\n params: { transitionHeight: transitionHeight }\n }\"\n (@expansionAnimation.done)=\"animationEnd()\"\n class=\"sky-text-expand-container\"\n #container\n>\n <span class=\"sky-text-expand-text\" [id]=\"contentSectionId\" #text></span>\n <span class=\"sky-text-expand-ellipsis\" *ngIf=\"!isExpanded && expandable\"\n >...\n </span>\n <button\n *ngIf=\"expandable\"\n type=\"button\"\n class=\"sky-btn sky-btn-link-inline sky-text-expand-see-more\"\n [attr.aria-expanded]=\"isModal ? undefined : !!isExpanded\"\n [attr.aria-controls]=\"isModal ? undefined : contentSectionId\"\n [attr.aria-haspopup]=\"isModal ? 'dialog' : undefined\"\n (click)=\"textExpand()\"\n >\n {{ buttonText }}\n </button>\n</div>\n", styles: [".sky-text-expand-ellipsis{letter-spacing:2px;white-space:nowrap}.sky-text-expand-space{white-space:normal}.sky-text-expand-see-more{white-space:nowrap;margin-left:5px}.sky-text-expand-text{margin:0;white-space:pre-wrap}.sky-text-expand-container{word-break:break-word;word-wrap:break-word;overflow:hidden;height:auto}.sky-text-expand-modal-content{white-space:pre-line;word-wrap:break-word}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], animations: [
254
+ trigger('expansionAnimation', [
255
+ transition(':enter', []),
256
+ state('true', style({
257
+ maxHeight: '{{transitionHeight}}px',
258
+ }), { params: { transitionHeight: 0 } }),
259
+ state('false', style({
260
+ maxHeight: '{{transitionHeight}}px',
261
+ }), { params: { transitionHeight: 0 } }),
262
+ transition('true => false', animate('250ms ease')),
263
+ transition('false => true', animate('250ms ease')),
264
+ transition('void => *', []),
265
+ ]),
266
+ ] });
219
267
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTextExpandComponent, decorators: [{
220
268
  type: Component,
221
- args: [{ selector: 'sky-text-expand', providers: [SkyTextExpandAdapterService], template: "<div\n class=\"sky-text-expand-container\"\n (transitionend)=\"animationEnd()\"\n #container\n>\n <span class=\"sky-text-expand-text\" [id]=\"contentSectionId\" #text></span>\n <span class=\"sky-text-expand-ellipsis\" *ngIf=\"!isExpanded && expandable\"\n >...\n </span>\n <button\n *ngIf=\"expandable\"\n type=\"button\"\n class=\"sky-btn sky-btn-link-inline sky-text-expand-see-more\"\n [attr.aria-expanded]=\"isModal ? undefined : isExpanded\"\n [attr.aria-controls]=\"isModal ? undefined : contentSectionId\"\n [attr.aria-haspopup]=\"isModal ? 'dialog' : undefined\"\n (click)=\"textExpand()\"\n >\n {{ buttonText }}\n </button>\n</div>\n", styles: [".sky-text-expand-ellipsis{letter-spacing:2px;white-space:nowrap}.sky-text-expand-space{white-space:normal}.sky-text-expand-see-more{white-space:nowrap;margin-left:5px}.sky-text-expand-text{margin:0;white-space:pre-wrap}.sky-text-expand-container{word-break:break-word;word-wrap:break-word;overflow:hidden;height:auto;transition:max-height .25s}.sky-text-expand-modal-content{white-space:pre-line;word-wrap:break-word}\n"] }]
269
+ args: [{ animations: [
270
+ trigger('expansionAnimation', [
271
+ transition(':enter', []),
272
+ state('true', style({
273
+ maxHeight: '{{transitionHeight}}px',
274
+ }), { params: { transitionHeight: 0 } }),
275
+ state('false', style({
276
+ maxHeight: '{{transitionHeight}}px',
277
+ }), { params: { transitionHeight: 0 } }),
278
+ transition('true => false', animate('250ms ease')),
279
+ transition('false => true', animate('250ms ease')),
280
+ transition('void => *', []),
281
+ ]),
282
+ ], selector: 'sky-text-expand', providers: [SkyTextExpandAdapterService], template: "<div\n [@expansionAnimation]=\"{\n value: isExpanded,\n params: { transitionHeight: transitionHeight }\n }\"\n (@expansionAnimation.done)=\"animationEnd()\"\n class=\"sky-text-expand-container\"\n #container\n>\n <span class=\"sky-text-expand-text\" [id]=\"contentSectionId\" #text></span>\n <span class=\"sky-text-expand-ellipsis\" *ngIf=\"!isExpanded && expandable\"\n >...\n </span>\n <button\n *ngIf=\"expandable\"\n type=\"button\"\n class=\"sky-btn sky-btn-link-inline sky-text-expand-see-more\"\n [attr.aria-expanded]=\"isModal ? undefined : !!isExpanded\"\n [attr.aria-controls]=\"isModal ? undefined : contentSectionId\"\n [attr.aria-haspopup]=\"isModal ? 'dialog' : undefined\"\n (click)=\"textExpand()\"\n >\n {{ buttonText }}\n </button>\n</div>\n", styles: [".sky-text-expand-ellipsis{letter-spacing:2px;white-space:nowrap}.sky-text-expand-space{white-space:normal}.sky-text-expand-see-more{white-space:nowrap;margin-left:5px}.sky-text-expand-text{margin:0;white-space:pre-wrap}.sky-text-expand-container{word-break:break-word;word-wrap:break-word;overflow:hidden;height:auto}.sky-text-expand-modal-content{white-space:pre-line;word-wrap:break-word}\n"] }]
222
283
  }], ctorParameters: function () { return [{ type: i1.SkyLibResourcesService }, { type: i2.SkyModalService }, { type: i3.SkyTextExpandAdapterService }]; }, propDecorators: { expandModalTitle: [{
223
284
  type: Input
224
285
  }], maxExpandedLength: [{
@@ -244,4 +305,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
244
305
  static: true,
245
306
  }]
246
307
  }] } });
247
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-expand.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/layout/src/lib/modules/text-expand/text-expand.component.ts","../../../../../../../../libs/components/layout/src/lib/modules/text-expand/text-expand.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ElementRef,\n  Input,\n  ViewChild,\n} from '@angular/core';\nimport { SkyLibResourcesService } from '@skyux/i18n';\nimport { SkyModalService } from '@skyux/modals';\n\nimport { forkJoin as observableForkJoin } from 'rxjs';\nimport { take } from 'rxjs/operators';\n\nimport { SkyTextExpandAdapterService } from './text-expand-adapter.service';\nimport { SkyTextExpandModalContext } from './text-expand-modal-context';\nimport { SkyTextExpandModalComponent } from './text-expand-modal.component';\n\n/**\n * Auto-incrementing integer used to generate unique ids for text expand components.\n */\nlet nextId = 0;\n\n@Component({\n  selector: 'sky-text-expand',\n  templateUrl: './text-expand.component.html',\n  styleUrls: ['./text-expand.component.scss'],\n  providers: [SkyTextExpandAdapterService],\n})\nexport class SkyTextExpandComponent implements AfterContentInit {\n  /**\n   * Specifies a title to display when the component expands the full text in a modal.\n   * @default \"Expanded view\"\n   */\n  @Input()\n  public expandModalTitle: string;\n\n  /**\n   * Specifies the maximum number of text characters to display inline when users select the link\n   * to expand the full text. If the text exceeds this limit, then the component expands\n   * the full text in a modal instead.\n   */\n  @Input()\n  public maxExpandedLength = 600;\n\n  /**\n   * Specifies the maximum number of newline characters to display inline when users select\n   * the link to expand the full text. If the text exceeds this limit, then\n   * the component expands the full text in a modal view instead.\n   */\n  @Input()\n  public maxExpandedNewlines = 2;\n\n  /**\n   * Specifies the number of text characters to display before truncating the text.\n   * To avoid truncating text in the middle of a word, the component looks for a space\n   * in the 10 characters before the last character.\n   * @default 200\n   */\n  @Input()\n  public set maxLength(value: number) {\n    this._maxLength = value;\n\n    /* istanbul ignore else */\n    if (this.textEl) {\n      this.setup(this.expandedText);\n    }\n  }\n\n  public get maxLength(): number {\n    return this._maxLength;\n  }\n\n  /**\n   * Specifies the text to truncate.\n   */\n  @Input()\n  public set text(value: string) {\n    /* istanbul ignore else */\n    if (this.textEl) {\n      this.setup(value);\n    }\n  }\n\n  /**\n   * Indicates whether to replace newline characters in truncated text with spaces.\n   */\n  @Input()\n  public truncateNewlines = true;\n\n  public buttonText: string;\n\n  public contentSectionId = `sky-text-expand-content-${++nextId}`;\n\n  public expandable: boolean;\n\n  public isExpanded = false;\n\n  public isModal: boolean;\n\n  @ViewChild('container', {\n    read: ElementRef,\n    static: true,\n  })\n  private containerEl: ElementRef;\n\n  @ViewChild('text', {\n    read: ElementRef,\n    static: true,\n  })\n  private textEl: ElementRef;\n\n  private collapsedText: string;\n\n  private expandedText: string;\n\n  private newlineCount: number;\n\n  private seeMoreText: string;\n\n  private seeLessText: string;\n\n  private textToShow: string;\n\n  private _maxLength = 200;\n\n  constructor(\n    private resources: SkyLibResourcesService,\n    private modalService: SkyModalService,\n    private textExpandAdapter: SkyTextExpandAdapterService\n  ) {}\n\n  public textExpand(): void {\n    if (this.isModal) {\n      // Modal View\n      /* istanbul ignore else */\n      /* sanity check */\n      if (!this.isExpanded) {\n        this.modalService.open(SkyTextExpandModalComponent, [\n          {\n            provide: SkyTextExpandModalContext,\n            useValue: {\n              header: this.expandModalTitle,\n              text: this.expandedText,\n            },\n          },\n        ]);\n      }\n    } else {\n      // Normal View\n      if (!this.isExpanded) {\n        this.setContainerMaxHeight();\n        setTimeout(() => {\n          this.isExpanded = true;\n          this.animateText(this.collapsedText, this.expandedText, true);\n        }, 10);\n      } else {\n        this.setContainerMaxHeight();\n        setTimeout(() => {\n          this.isExpanded = false;\n          this.animateText(this.expandedText, this.collapsedText, false);\n        }, 10);\n      }\n    }\n  }\n\n  public animationEnd(): void {\n    // Ensure the correct text is displayed\n    this.textExpandAdapter.setText(this.textEl, this.textToShow);\n    // Set height back to auto so the browser can change the height as needed with window changes\n    this.textExpandAdapter.setContainerHeight(this.containerEl, undefined);\n  }\n\n  public ngAfterContentInit(): void {\n    observableForkJoin([\n      this.resources.getString('skyux_text_expand_see_more'),\n      this.resources.getString('skyux_text_expand_see_less'),\n    ])\n      .pipe(take(1))\n      .subscribe((resources) => {\n        this.seeMoreText = resources[0];\n        this.seeLessText = resources[1];\n        this.setup(this.expandedText);\n\n        /* istanbul ignore else */\n        if (!this.expandModalTitle) {\n          this.resources\n            .getString('skyux_text_expand_modal_title')\n            .pipe(take(1))\n            .subscribe((resource) => {\n              this.expandModalTitle = resource;\n            });\n        }\n      });\n  }\n\n  private setContainerMaxHeight(): void {\n    // ensure everything is reset\n    this.animationEnd();\n    /* Before animation is kicked off, ensure that a maxHeight exists */\n    /* Once we have support for angular v4 animations with parameters we can use that instead */\n    const currentHeight = this.textExpandAdapter.getContainerHeight(\n      this.containerEl\n    );\n    this.textExpandAdapter.setContainerHeight(\n      this.containerEl,\n      `${currentHeight}px`\n    );\n  }\n\n  private setup(value: string): void {\n    if (value) {\n      this.newlineCount = this.getNewlineCount(value);\n      this.collapsedText = this.getTruncatedText(value, this.maxLength);\n      this.expandedText = value;\n      if (this.collapsedText !== value) {\n        this.buttonText = this.seeMoreText;\n        this.isExpanded = false;\n        this.expandable = true;\n        this.isModal =\n          this.newlineCount > this.maxExpandedNewlines ||\n          this.expandedText.length > this.maxExpandedLength;\n      } else {\n        this.expandable = false;\n      }\n      this.textToShow = this.collapsedText;\n    } else {\n      this.textToShow = '';\n      this.expandable = false;\n    }\n    this.textExpandAdapter.setText(this.textEl, this.textToShow);\n  }\n\n  private getNewlineCount(value: string): number {\n    const matches = value.match(/\\n/gi);\n\n    if (matches) {\n      return matches.length;\n    }\n\n    return 0;\n  }\n\n  private getTruncatedText(value: string, length: number): string {\n    let i: number;\n    if (this.truncateNewlines) {\n      value = value.replace(/\\n+/gi, ' ');\n    }\n    // Jump ahead one character and see if it's a space, and if it isn't,\n    // back up to the first space and break there so a word doesn't get cut\n    // in half.\n    if (length < value.length) {\n      for (i = length; i > length - 10; i--) {\n        if (/\\s/.test(value.charAt(i))) {\n          length = i;\n          break;\n        }\n      }\n    }\n    return value.substr(0, length);\n  }\n\n  private animateText(\n    previousText: string,\n    newText: string,\n    expanding: boolean\n  ): void {\n    const adapter = this.textExpandAdapter;\n    const container = this.containerEl;\n    // Reset max height\n    adapter.setContainerHeight(container, undefined);\n    // Measure the current height so we can animate from it.\n    const currentHeight = adapter.getContainerHeight(container);\n    this.textToShow = newText;\n    adapter.setText(this.textEl, this.textToShow);\n    this.buttonText = expanding ? this.seeLessText : this.seeMoreText;\n    // Measure the new height so we can animate to it.\n    const newHeight = adapter.getContainerHeight(container);\n    /* istanbul ignore if */\n    if (newHeight < currentHeight) {\n      // The new text is smaller than the old text, so put the old text back before doing\n      // the collapse animation to avoid showing a big chunk of whitespace.\n      adapter.setText(this.textEl, previousText);\n    }\n\n    adapter.setContainerHeight(container, `${currentHeight}px`);\n    // This timeout is necessary due to the browser needing to pick up the non-auto height being set\n    // in order to do the transtion in height correctly. Without it the transition does not fire.\n    setTimeout(() => {\n      adapter.setContainerHeight(container, `${newHeight}px`);\n      /* This resets values if the transition does not get kicked off */\n      setTimeout(() => {\n        this.animationEnd();\n      }, 500);\n    }, 10);\n  }\n}\n","<div\n  class=\"sky-text-expand-container\"\n  (transitionend)=\"animationEnd()\"\n  #container\n>\n  <span class=\"sky-text-expand-text\" [id]=\"contentSectionId\" #text></span>\n  <span class=\"sky-text-expand-ellipsis\" *ngIf=\"!isExpanded && expandable\"\n    >...\n  </span>\n  <button\n    *ngIf=\"expandable\"\n    type=\"button\"\n    class=\"sky-btn sky-btn-link-inline sky-text-expand-see-more\"\n    [attr.aria-expanded]=\"isModal ? undefined : isExpanded\"\n    [attr.aria-controls]=\"isModal ? undefined : contentSectionId\"\n    [attr.aria-haspopup]=\"isModal ? 'dialog' : undefined\"\n    (click)=\"textExpand()\"\n  >\n    {{ buttonText }}\n  </button>\n</div>\n"]}
308
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-expand.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/layout/src/lib/modules/text-expand/text-expand.component.ts","../../../../../../../../libs/components/layout/src/lib/modules/text-expand/text-expand.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  state,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations';\nimport {\n  AfterContentInit,\n  Component,\n  ElementRef,\n  Input,\n  ViewChild,\n} from '@angular/core';\nimport { SkyLibResourcesService } from '@skyux/i18n';\nimport { SkyModalService } from '@skyux/modals';\n\nimport { forkJoin as observableForkJoin } from 'rxjs';\nimport { take } from 'rxjs/operators';\n\nimport { SkyTextExpandAdapterService } from './text-expand-adapter.service';\nimport { SKY_TEXT_EXPAND_MODAL_CONTEXT } from './text-expand-modal-context-token';\nimport { SkyTextExpandModalComponent } from './text-expand-modal.component';\n\n/**\n * Auto-incrementing integer used to generate unique ids for text expand components.\n */\nlet nextId = 0;\n\n@Component({\n  animations: [\n    trigger('expansionAnimation', [\n      transition(':enter', []),\n      state(\n        'true',\n        style({\n          maxHeight: '{{transitionHeight}}px',\n        }),\n        { params: { transitionHeight: 0 } }\n      ),\n      state(\n        'false',\n        style({\n          maxHeight: '{{transitionHeight}}px',\n        }),\n        { params: { transitionHeight: 0 } }\n      ),\n      transition('true => false', animate('250ms ease')),\n      transition('false => true', animate('250ms ease')),\n      transition('void => *', []),\n    ]),\n  ],\n  selector: 'sky-text-expand',\n  templateUrl: './text-expand.component.html',\n  styleUrls: ['./text-expand.component.scss'],\n  providers: [SkyTextExpandAdapterService],\n})\nexport class SkyTextExpandComponent implements AfterContentInit {\n  /**\n   * Specifies a title to display when the component expands the full text in a modal.\n   * @default \"Expanded view\"\n   */\n  @Input()\n  public expandModalTitle: string | undefined;\n\n  /**\n   * Specifies the maximum number of text characters to display inline when users select the link\n   * to expand the full text. If the text exceeds this limit, then the component expands\n   * the full text in a modal instead.\n   * @default 600\n   */\n  @Input()\n  public set maxExpandedLength(value: number | undefined) {\n    if (value) {\n      this.#_maxExpandedLength = value;\n    } else {\n      this.#_maxExpandedLength = 600;\n    }\n    this.#setup(this.text);\n  }\n\n  public get maxExpandedLength(): number {\n    return this.#_maxExpandedLength;\n  }\n\n  /**\n   * Specifies the maximum number of newline characters to display inline when users select\n   * the link to expand the full text. If the text exceeds this limit, then\n   * the component expands the full text in a modal view instead.\n   * @default 2\n   */\n  @Input()\n  public set maxExpandedNewlines(value: number | undefined) {\n    if (value) {\n      this.#_maxExpandedNewlines = value;\n    } else {\n      this.#_maxExpandedNewlines = 2;\n    }\n    this.#setup(this.text);\n  }\n\n  public get maxExpandedNewlines(): number {\n    return this.#_maxExpandedNewlines;\n  }\n\n  /**\n   * Specifies the number of text characters to display before truncating the text.\n   * To avoid truncating text in the middle of a word, the component looks for a space\n   * in the 10 characters before the last character.\n   * @default 200\n   */\n  @Input()\n  public set maxLength(value: number | undefined) {\n    if (value) {\n      this.#_maxLength = value;\n    } else {\n      this.#_maxLength = 200;\n    }\n    this.#setup(this.text);\n  }\n\n  public get maxLength(): number {\n    return this.#_maxLength;\n  }\n\n  /**\n   * Specifies the text to truncate.\n   */\n  @Input()\n  public set text(value: string | undefined) {\n    this.#_text = value ?? '';\n    this.#setup(this.#_text);\n  }\n\n  public get text(): string {\n    return this.#_text;\n  }\n\n  /**\n   * Indicates whether to replace newline characters in truncated text with spaces.\n   */\n  @Input()\n  public truncateNewlines = true;\n\n  public buttonText = '';\n\n  public contentSectionId = `sky-text-expand-content-${++nextId}`;\n\n  public expandable = false;\n\n  public isExpanded: boolean | undefined;\n\n  public isModal = false;\n\n  public transitionHeight = 1;\n\n  @ViewChild('container', {\n    read: ElementRef,\n    static: true,\n  })\n  public containerEl: ElementRef | undefined;\n\n  @ViewChild('text', {\n    read: ElementRef,\n    static: true,\n  })\n  public set textEl(value: ElementRef | undefined) {\n    this.#_textEl = value;\n    this.#setup(this.text);\n  }\n\n  public get textEl(): ElementRef | undefined {\n    return this.#_textEl;\n  }\n\n  #collapsedText = '';\n\n  #newlineCount = 0;\n\n  #seeMoreText = '';\n\n  #seeLessText = '';\n\n  #textToShow = '';\n\n  #_maxExpandedLength = 600;\n\n  #_maxExpandedNewlines = 2;\n\n  #_maxLength = 200;\n\n  #_text = '';\n\n  #_textEl: ElementRef | undefined;\n\n  #resources: SkyLibResourcesService;\n  #modalSvc: SkyModalService;\n  #textExpandAdapter: SkyTextExpandAdapterService;\n\n  constructor(\n    resources: SkyLibResourcesService,\n    modalSvc: SkyModalService,\n    textExpandAdapter: SkyTextExpandAdapterService\n  ) {\n    this.#resources = resources;\n    this.#modalSvc = modalSvc;\n    this.#textExpandAdapter = textExpandAdapter;\n  }\n\n  public textExpand(): void {\n    if (this.isModal) {\n      // Modal View\n      /* istanbul ignore else */\n      /* sanity check */\n      if (!this.isExpanded) {\n        this.#modalSvc.open(SkyTextExpandModalComponent, [\n          {\n            provide: SKY_TEXT_EXPAND_MODAL_CONTEXT,\n            useValue: {\n              header: this.expandModalTitle,\n              text: this.text,\n            },\n          },\n        ]);\n      }\n    } else {\n      // Normal View\n      if (!this.isExpanded) {\n        this.#animateText(true);\n      } else {\n        this.#animateText(false);\n      }\n    }\n  }\n\n  public animationEnd(): void {\n    if (this.textEl && this.containerEl) {\n      // Ensure the correct text is displayed\n      this.#textExpandAdapter.setText(this.textEl, this.#textToShow);\n\n      setTimeout(() => {\n        if (this.containerEl) {\n          // Set height back to auto so the browser can change the height as needed with window changes\n          this.#textExpandAdapter.removeContainerMaxHeight(this.containerEl);\n        }\n      });\n    }\n  }\n\n  public ngAfterContentInit(): void {\n    observableForkJoin([\n      this.#resources.getString('skyux_text_expand_see_more'),\n      this.#resources.getString('skyux_text_expand_see_less'),\n    ])\n      .pipe(take(1))\n      .subscribe((resources) => {\n        this.#seeMoreText = resources[0];\n        this.#seeLessText = resources[1];\n        this.#setup(this.text);\n\n        /* istanbul ignore else */\n        if (!this.expandModalTitle) {\n          this.#resources\n            .getString('skyux_text_expand_modal_title')\n            .pipe(take(1))\n            .subscribe((resource) => {\n              this.expandModalTitle = resource;\n            });\n        }\n      });\n  }\n\n  #setup(value: string | undefined): void {\n    if (value) {\n      this.#newlineCount = this.#getNewlineCount(value);\n      this.#collapsedText = this.#getTruncatedText(value, this.maxLength);\n      if (this.#collapsedText !== value) {\n        this.buttonText = this.#seeMoreText;\n        this.isExpanded = false;\n        this.expandable = true;\n        this.isModal =\n          this.#newlineCount > this.maxExpandedNewlines ||\n          this.text.length > this.maxExpandedLength;\n      } else {\n        this.expandable = false;\n      }\n      this.#textToShow = this.#collapsedText;\n    } else {\n      this.#textToShow = '';\n      this.expandable = false;\n    }\n    if (this.textEl) {\n      this.#textExpandAdapter.setText(this.textEl, this.#textToShow);\n    }\n  }\n\n  #getNewlineCount(value: string): number {\n    const matches = value.match(/\\n/gi);\n\n    if (matches) {\n      return matches.length;\n    }\n\n    return 0;\n  }\n\n  #getTruncatedText(value: string, length: number): string {\n    let i: number;\n    if (this.truncateNewlines) {\n      value = value.replace(/\\n+/gi, ' ');\n    }\n    // Jump ahead one character and see if it's a space, and if it isn't,\n    // back up to the first space and break there so a word doesn't get cut\n    // in half.\n    if (length < value.length) {\n      for (i = length; i > length - 10; i--) {\n        if (/\\s/.test(value.charAt(i))) {\n          length = i;\n          break;\n        }\n      }\n    }\n    return value.substring(0, length);\n  }\n\n  #animateText(expanding: boolean): void {\n    if (this.containerEl && this.textEl) {\n      const adapter = this.#textExpandAdapter;\n      const container = this.containerEl;\n      if (expanding) {\n        adapter.setText(this.textEl, this.text);\n        this.#textToShow = this.text;\n      } else {\n        adapter.setText(this.textEl, this.#collapsedText);\n        this.#textToShow = this.#collapsedText;\n      }\n      this.buttonText = expanding ? this.#seeLessText : this.#seeMoreText;\n      // Measure the new height so we can animate to it.\n      const newHeight = adapter.getContainerHeight(container);\n      this.transitionHeight = newHeight;\n      // Always show all text while animating so that the animation is smooth. The animation callback will set this back if needed.\n      if (!expanding) {\n        adapter.setText(this.textEl, this.text);\n      }\n      this.isExpanded = expanding;\n    }\n  }\n}\n","<div\n  [@expansionAnimation]=\"{\n    value: isExpanded,\n    params: { transitionHeight: transitionHeight }\n  }\"\n  (@expansionAnimation.done)=\"animationEnd()\"\n  class=\"sky-text-expand-container\"\n  #container\n>\n  <span class=\"sky-text-expand-text\" [id]=\"contentSectionId\" #text></span>\n  <span class=\"sky-text-expand-ellipsis\" *ngIf=\"!isExpanded && expandable\"\n    >...\n  </span>\n  <button\n    *ngIf=\"expandable\"\n    type=\"button\"\n    class=\"sky-btn sky-btn-link-inline sky-text-expand-see-more\"\n    [attr.aria-expanded]=\"isModal ? undefined : !!isExpanded\"\n    [attr.aria-controls]=\"isModal ? undefined : contentSectionId\"\n    [attr.aria-haspopup]=\"isModal ? 'dialog' : undefined\"\n    (click)=\"textExpand()\"\n  >\n    {{ buttonText }}\n  </button>\n</div>\n"]}
@@ -1,3 +1,5 @@
1
+ var _SkyTextExpandRepeaterAdapterService_renderer;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { Injectable, RendererFactory2, } from '@angular/core';
2
4
  import * as i0 from "@angular/core";
3
5
  /**
@@ -5,33 +7,29 @@ import * as i0 from "@angular/core";
5
7
  */
6
8
  export class SkyTextExpandRepeaterAdapterService {
7
9
  constructor(rendererFactory) {
8
- this.rendererFactory = rendererFactory;
9
- this.renderer = this.rendererFactory.createRenderer(undefined, undefined);
10
+ _SkyTextExpandRepeaterAdapterService_renderer.set(this, void 0);
11
+ __classPrivateFieldSet(this, _SkyTextExpandRepeaterAdapterService_renderer, rendererFactory.createRenderer(undefined, null), "f");
10
12
  }
11
13
  getItems(elRef) {
12
14
  return elRef.nativeElement.querySelectorAll('.sky-text-expand-repeater-item');
13
15
  }
14
16
  hideItem(item) {
15
- this.renderer.setStyle(item, 'display', 'none');
17
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterAdapterService_renderer, "f").setStyle(item, 'display', 'none');
16
18
  }
17
19
  showItem(item) {
18
- this.renderer.setStyle(item, 'display', 'list-item');
20
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterAdapterService_renderer, "f").removeStyle(item, 'display');
19
21
  }
20
22
  getContainerHeight(containerEl) {
21
23
  return containerEl.nativeElement.offsetHeight;
22
24
  }
23
- setContainerHeight(containerEl, height) {
24
- if (height === undefined) {
25
- this.renderer.removeStyle(containerEl.nativeElement, 'max-height');
26
- }
27
- else {
28
- this.renderer.setStyle(containerEl.nativeElement, 'max-height', height);
29
- }
25
+ removeContainerMaxHeight(containerEl) {
26
+ __classPrivateFieldGet(this, _SkyTextExpandRepeaterAdapterService_renderer, "f").removeStyle(containerEl.nativeElement, 'max-height');
30
27
  }
31
28
  }
29
+ _SkyTextExpandRepeaterAdapterService_renderer = new WeakMap();
32
30
  SkyTextExpandRepeaterAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTextExpandRepeaterAdapterService, deps: [{ token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable });
33
31
  SkyTextExpandRepeaterAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTextExpandRepeaterAdapterService });
34
32
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTextExpandRepeaterAdapterService, decorators: [{
35
33
  type: Injectable
36
34
  }], ctorParameters: function () { return [{ type: i0.RendererFactory2 }]; } });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1leHBhbmQtcmVwZWF0ZXItYWRhcHRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC9zcmMvbGliL21vZHVsZXMvdGV4dC1leHBhbmQtcmVwZWF0ZXIvdGV4dC1leHBhbmQtcmVwZWF0ZXItYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxVQUFVLEVBRVYsZ0JBQWdCLEdBQ2pCLE1BQU0sZUFBZSxDQUFDOztBQUV2Qjs7R0FFRztBQUVILE1BQU0sT0FBTyxtQ0FBbUM7SUFHOUMsWUFBb0IsZUFBaUM7UUFBakMsb0JBQWUsR0FBZixlQUFlLENBQWtCO1FBQ25ELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQzVFLENBQUM7SUFFTSxRQUFRLENBQUMsS0FBaUI7UUFDL0IsT0FBTyxLQUFLLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUN6QyxnQ0FBZ0MsQ0FDakMsQ0FBQztJQUNKLENBQUM7SUFFTSxRQUFRLENBQUMsSUFBaUI7UUFDL0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRU0sUUFBUSxDQUFDLElBQWlCO1FBQy9CLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVNLGtCQUFrQixDQUFDLFdBQXVCO1FBQy9DLE9BQU8sV0FBVyxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUM7SUFDaEQsQ0FBQztJQUVNLGtCQUFrQixDQUFDLFdBQXVCLEVBQUUsTUFBYztRQUMvRCxJQUFJLE1BQU0sS0FBSyxTQUFTLEVBQUU7WUFDeEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUFDLGFBQWEsRUFBRSxZQUFZLENBQUMsQ0FBQztTQUNwRTthQUFNO1lBQ0wsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLGFBQWEsRUFBRSxZQUFZLEVBQUUsTUFBTSxDQUFDLENBQUM7U0FDekU7SUFDSCxDQUFDOztnSUEvQlUsbUNBQW1DO29JQUFuQyxtQ0FBbUM7MkZBQW5DLG1DQUFtQztrQkFEL0MsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEVsZW1lbnRSZWYsXG4gIEluamVjdGFibGUsXG4gIFJlbmRlcmVyMixcbiAgUmVuZGVyZXJGYWN0b3J5Mixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTa3lUZXh0RXhwYW5kUmVwZWF0ZXJBZGFwdGVyU2VydmljZSB7XG4gIHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMjtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlbmRlcmVyRmFjdG9yeTogUmVuZGVyZXJGYWN0b3J5Mikge1xuICAgIHRoaXMucmVuZGVyZXIgPSB0aGlzLnJlbmRlcmVyRmFjdG9yeS5jcmVhdGVSZW5kZXJlcih1bmRlZmluZWQsIHVuZGVmaW5lZCk7XG4gIH1cblxuICBwdWJsaWMgZ2V0SXRlbXMoZWxSZWY6IEVsZW1lbnRSZWYpIHtcbiAgICByZXR1cm4gZWxSZWYubmF0aXZlRWxlbWVudC5xdWVyeVNlbGVjdG9yQWxsKFxuICAgICAgJy5za3ktdGV4dC1leHBhbmQtcmVwZWF0ZXItaXRlbSdcbiAgICApO1xuICB9XG5cbiAgcHVibGljIGhpZGVJdGVtKGl0ZW06IEhUTUxFbGVtZW50KSB7XG4gICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZShpdGVtLCAnZGlzcGxheScsICdub25lJyk7XG4gIH1cblxuICBwdWJsaWMgc2hvd0l0ZW0oaXRlbTogSFRNTEVsZW1lbnQpIHtcbiAgICB0aGlzLnJlbmRlcmVyLnNldFN0eWxlKGl0ZW0sICdkaXNwbGF5JywgJ2xpc3QtaXRlbScpO1xuICB9XG5cbiAgcHVibGljIGdldENvbnRhaW5lckhlaWdodChjb250YWluZXJFbDogRWxlbWVudFJlZikge1xuICAgIHJldHVybiBjb250YWluZXJFbC5uYXRpdmVFbGVtZW50Lm9mZnNldEhlaWdodDtcbiAgfVxuXG4gIHB1YmxpYyBzZXRDb250YWluZXJIZWlnaHQoY29udGFpbmVyRWw6IEVsZW1lbnRSZWYsIGhlaWdodDogc3RyaW5nKSB7XG4gICAgaWYgKGhlaWdodCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICB0aGlzLnJlbmRlcmVyLnJlbW92ZVN0eWxlKGNvbnRhaW5lckVsLm5hdGl2ZUVsZW1lbnQsICdtYXgtaGVpZ2h0Jyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUoY29udGFpbmVyRWwubmF0aXZlRWxlbWVudCwgJ21heC1oZWlnaHQnLCBoZWlnaHQpO1xuICAgIH1cbiAgfVxufVxuIl19
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1leHBhbmQtcmVwZWF0ZXItYWRhcHRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC9zcmMvbGliL21vZHVsZXMvdGV4dC1leHBhbmQtcmVwZWF0ZXIvdGV4dC1leHBhbmQtcmVwZWF0ZXItYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUVMLFVBQVUsRUFFVixnQkFBZ0IsR0FDakIsTUFBTSxlQUFlLENBQUM7O0FBRXZCOztHQUVHO0FBRUgsTUFBTSxPQUFPLG1DQUFtQztJQUc5QyxZQUFZLGVBQWlDO1FBRjdDLGdFQUFxQjtRQUduQix1QkFBQSxJQUFJLGlEQUFhLGVBQWUsQ0FBQyxjQUFjLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxNQUFBLENBQUM7SUFDbkUsQ0FBQztJQUVNLFFBQVEsQ0FBQyxLQUFpQjtRQUMvQixPQUFRLEtBQUssQ0FBQyxhQUE2QixDQUFDLGdCQUFnQixDQUMxRCxnQ0FBZ0MsQ0FDTixDQUFDO0lBQy9CLENBQUM7SUFFTSxRQUFRLENBQUMsSUFBaUI7UUFDL0IsdUJBQUEsSUFBSSxxREFBVSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFTSxRQUFRLENBQUMsSUFBaUI7UUFDL0IsdUJBQUEsSUFBSSxxREFBVSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVNLGtCQUFrQixDQUFDLFdBQXVCO1FBQy9DLE9BQU8sV0FBVyxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUM7SUFDaEQsQ0FBQztJQUVNLHdCQUF3QixDQUFDLFdBQXVCO1FBQ3JELHVCQUFBLElBQUkscURBQVUsQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUFDLGFBQWEsRUFBRSxZQUFZLENBQUMsQ0FBQztJQUN0RSxDQUFDOzs7Z0lBM0JVLG1DQUFtQztvSUFBbkMsbUNBQW1DOzJGQUFuQyxtQ0FBbUM7a0JBRC9DLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBFbGVtZW50UmVmLFxuICBJbmplY3RhYmxlLFxuICBSZW5kZXJlcjIsXG4gIFJlbmRlcmVyRmFjdG9yeTIsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2t5VGV4dEV4cGFuZFJlcGVhdGVyQWRhcHRlclNlcnZpY2Uge1xuICAjcmVuZGVyZXI6IFJlbmRlcmVyMjtcblxuICBjb25zdHJ1Y3RvcihyZW5kZXJlckZhY3Rvcnk6IFJlbmRlcmVyRmFjdG9yeTIpIHtcbiAgICB0aGlzLiNyZW5kZXJlciA9IHJlbmRlcmVyRmFjdG9yeS5jcmVhdGVSZW5kZXJlcih1bmRlZmluZWQsIG51bGwpO1xuICB9XG5cbiAgcHVibGljIGdldEl0ZW1zKGVsUmVmOiBFbGVtZW50UmVmKTogTm9kZUxpc3RPZjxIVE1MRWxlbWVudD4ge1xuICAgIHJldHVybiAoZWxSZWYubmF0aXZlRWxlbWVudCBhcyBIVE1MRWxlbWVudCkucXVlcnlTZWxlY3RvckFsbChcbiAgICAgICcuc2t5LXRleHQtZXhwYW5kLXJlcGVhdGVyLWl0ZW0nXG4gICAgKSBhcyBOb2RlTGlzdE9mPEhUTUxFbGVtZW50PjtcbiAgfVxuXG4gIHB1YmxpYyBoaWRlSXRlbShpdGVtOiBIVE1MRWxlbWVudCk6IHZvaWQge1xuICAgIHRoaXMuI3JlbmRlcmVyLnNldFN0eWxlKGl0ZW0sICdkaXNwbGF5JywgJ25vbmUnKTtcbiAgfVxuXG4gIHB1YmxpYyBzaG93SXRlbShpdGVtOiBIVE1MRWxlbWVudCk6IHZvaWQge1xuICAgIHRoaXMuI3JlbmRlcmVyLnJlbW92ZVN0eWxlKGl0ZW0sICdkaXNwbGF5Jyk7XG4gIH1cblxuICBwdWJsaWMgZ2V0Q29udGFpbmVySGVpZ2h0KGNvbnRhaW5lckVsOiBFbGVtZW50UmVmKTogbnVtYmVyIHtcbiAgICByZXR1cm4gY29udGFpbmVyRWwubmF0aXZlRWxlbWVudC5vZmZzZXRIZWlnaHQ7XG4gIH1cblxuICBwdWJsaWMgcmVtb3ZlQ29udGFpbmVyTWF4SGVpZ2h0KGNvbnRhaW5lckVsOiBFbGVtZW50UmVmKTogdm9pZCB7XG4gICAgdGhpcy4jcmVuZGVyZXIucmVtb3ZlU3R5bGUoY29udGFpbmVyRWwubmF0aXZlRWxlbWVudCwgJ21heC1oZWlnaHQnKTtcbiAgfVxufVxuIl19