@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.
- package/documentation.json +1679 -990
- package/esm2020/index.mjs +1 -2
- package/esm2020/lib/modules/action-button/action-button-adapter-service.mjs +22 -18
- package/esm2020/lib/modules/action-button/action-button-container.component.mjs +62 -54
- package/esm2020/lib/modules/action-button/action-button-icon.component.mjs +9 -6
- package/esm2020/lib/modules/action-button/action-button.component.mjs +10 -6
- package/esm2020/lib/modules/back-to-top/back-to-top-adapter.service.mjs +19 -15
- package/esm2020/lib/modules/back-to-top/back-to-top.component.mjs +8 -5
- package/esm2020/lib/modules/back-to-top/back-to-top.directive.mjs +68 -63
- package/esm2020/lib/modules/box/box.component.mjs +1 -1
- package/esm2020/lib/modules/card/card.component.mjs +38 -11
- package/esm2020/lib/modules/definition-list/definition-list-label.component.mjs +1 -1
- package/esm2020/lib/modules/definition-list/definition-list-value.component.mjs +3 -3
- package/esm2020/lib/modules/definition-list/definition-list.component.mjs +1 -1
- package/esm2020/lib/modules/definition-list/definition-list.service.mjs +1 -1
- package/esm2020/lib/modules/description-list/description-list-adapter-service.mjs +26 -22
- package/esm2020/lib/modules/description-list/description-list-content.component.mjs +2 -2
- package/esm2020/lib/modules/description-list/description-list-description.component.mjs +16 -11
- package/esm2020/lib/modules/description-list/description-list-term.component.mjs +1 -1
- package/esm2020/lib/modules/description-list/description-list.component.mjs +25 -16
- package/esm2020/lib/modules/fluid-grid/column.component.mjs +19 -1
- package/esm2020/lib/modules/fluid-grid/fluid-grid.component.mjs +15 -35
- package/esm2020/lib/modules/fluid-grid/row.component.mjs +1 -1
- package/esm2020/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.mjs +1 -1
- package/esm2020/lib/modules/format/format.component.mjs +34 -26
- package/esm2020/lib/modules/inline-delete/inline-delete-adapter.service.mjs +91 -83
- package/esm2020/lib/modules/inline-delete/inline-delete.component.mjs +15 -9
- package/esm2020/lib/modules/page/page-theme-adapter.service.mjs +14 -8
- package/esm2020/lib/modules/page/page.component.mjs +8 -4
- package/esm2020/lib/modules/page-summary/page-summary-adapter.service.mjs +1 -1
- package/esm2020/lib/modules/page-summary/page-summary.component.mjs +40 -16
- package/esm2020/lib/modules/text-expand/text-expand-adapter.service.mjs +8 -10
- package/esm2020/lib/modules/text-expand/text-expand-modal-context-token.mjs +6 -0
- package/esm2020/lib/modules/text-expand/text-expand-modal-context.mjs +2 -6
- package/esm2020/lib/modules/text-expand/text-expand-modal.component.mjs +12 -10
- package/esm2020/lib/modules/text-expand/text-expand.component.mjs +188 -127
- package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.mjs +10 -12
- package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater.component.mjs +139 -95
- package/esm2020/lib/modules/toolbar/toolbar.component.mjs +4 -4
- package/esm2020/testing/action-button-fixture.mjs +12 -6
- package/esm2020/testing/card-fixture.mjs +19 -16
- package/esm2020/testing/page-summary-fixture.mjs +9 -5
- package/fesm2015/skyux-layout-testing.mjs +35 -24
- package/fesm2015/skyux-layout-testing.mjs.map +1 -1
- package/fesm2015/skyux-layout.mjs +866 -673
- package/fesm2015/skyux-layout.mjs.map +1 -1
- package/fesm2020/skyux-layout-testing.mjs +35 -24
- package/fesm2020/skyux-layout-testing.mjs.map +1 -1
- package/fesm2020/skyux-layout.mjs +861 -673
- package/fesm2020/skyux-layout.mjs.map +1 -1
- package/index.d.ts +0 -1
- package/lib/modules/action-button/action-button-adapter-service.d.ts +1 -2
- package/lib/modules/action-button/action-button-container.component.d.ts +6 -17
- package/lib/modules/action-button/action-button-icon.component.d.ts +2 -3
- package/lib/modules/action-button/action-button.component.d.ts +3 -3
- package/lib/modules/back-to-top/back-to-top-adapter.service.d.ts +1 -4
- package/lib/modules/back-to-top/back-to-top.component.d.ts +1 -1
- package/lib/modules/back-to-top/back-to-top.directive.d.ts +4 -16
- package/lib/modules/box/box.component.d.ts +3 -3
- package/lib/modules/card/card.component.d.ts +7 -6
- package/lib/modules/definition-list/definition-list-label.component.d.ts +1 -1
- package/lib/modules/definition-list/definition-list-value.component.d.ts +1 -1
- package/lib/modules/definition-list/definition-list.component.d.ts +2 -2
- package/lib/modules/definition-list/definition-list.service.d.ts +2 -2
- package/lib/modules/description-list/description-list-adapter-service.d.ts +1 -2
- package/lib/modules/description-list/description-list-content.component.d.ts +2 -2
- package/lib/modules/description-list/description-list-description.component.d.ts +5 -7
- package/lib/modules/description-list/description-list-term.component.d.ts +1 -1
- package/lib/modules/description-list/description-list.component.d.ts +6 -7
- package/lib/modules/fluid-grid/column.component.d.ts +7 -5
- package/lib/modules/fluid-grid/fluid-grid.component.d.ts +3 -9
- package/lib/modules/fluid-grid/row.component.d.ts +1 -1
- package/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.d.ts +1 -1
- package/lib/modules/format/format.component.d.ts +5 -7
- package/lib/modules/inline-delete/inline-delete-adapter.service.d.ts +1 -11
- package/lib/modules/inline-delete/inline-delete.component.d.ts +3 -5
- package/lib/modules/page/page-theme-adapter.service.d.ts +1 -1
- package/lib/modules/page/page.component.d.ts +1 -1
- package/lib/modules/page-summary/page-summary.component.d.ts +8 -9
- package/lib/modules/text-expand/text-expand-adapter.service.d.ts +3 -4
- package/lib/modules/text-expand/text-expand-modal-context-token.d.ts +6 -0
- package/lib/modules/text-expand/text-expand-modal-context.d.ts +1 -1
- package/lib/modules/text-expand/text-expand.component.d.ts +18 -25
- package/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.d.ts +4 -5
- package/lib/modules/text-expand-repeater/text-expand-repeater.component.d.ts +13 -21
- package/lib/modules/toolbar/toolbar.component.d.ts +4 -4
- package/package.json +9 -9
- package/testing/action-button-fixture.d.ts +4 -4
- package/testing/card-fixture.d.ts +3 -5
- package/testing/page-summary-fixture.d.ts +4 -4
- package/esm2020/lib/modules/fluid-grid/fluid-grid-gutter-size.mjs +0 -20
- 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 {
|
|
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,
|
|
20
|
-
this
|
|
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.
|
|
41
|
-
this.
|
|
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
|
-
|
|
51
|
-
|
|
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
|
|
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
|
-
|
|
64
|
-
|
|
65
|
-
|
|
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.
|
|
127
|
+
__classPrivateFieldGet(this, _SkyTextExpandComponent_modalSvc, "f").open(SkyTextExpandModalComponent, [
|
|
75
128
|
{
|
|
76
|
-
provide:
|
|
129
|
+
provide: SKY_TEXT_EXPAND_MODAL_CONTEXT,
|
|
77
130
|
useValue: {
|
|
78
131
|
header: this.expandModalTitle,
|
|
79
|
-
text: this.
|
|
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.
|
|
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.
|
|
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
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
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.
|
|
112
|
-
this.
|
|
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
|
|
117
|
-
this
|
|
118
|
-
this.
|
|
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
|
|
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
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
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
|
|
197
|
+
__classPrivateFieldSet(this, _SkyTextExpandComponent_textToShow, __classPrivateFieldGet(this, _SkyTextExpandComponent_collapsedText, "f"), "f");
|
|
161
198
|
}
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
return matches.length;
|
|
166
|
-
}
|
|
167
|
-
return 0;
|
|
199
|
+
else {
|
|
200
|
+
__classPrivateFieldSet(this, _SkyTextExpandComponent_textToShow, '', "f");
|
|
201
|
+
this.expandable = false;
|
|
168
202
|
}
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
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
|
-
|
|
188
|
-
|
|
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
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
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
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
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
|
-
|
|
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
|
|
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: [{
|
|
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
|
|
9
|
-
this
|
|
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.
|
|
17
|
+
__classPrivateFieldGet(this, _SkyTextExpandRepeaterAdapterService_renderer, "f").setStyle(item, 'display', 'none');
|
|
16
18
|
}
|
|
17
19
|
showItem(item) {
|
|
18
|
-
this.
|
|
20
|
+
__classPrivateFieldGet(this, _SkyTextExpandRepeaterAdapterService_renderer, "f").removeStyle(item, 'display');
|
|
19
21
|
}
|
|
20
22
|
getContainerHeight(containerEl) {
|
|
21
23
|
return containerEl.nativeElement.offsetHeight;
|
|
22
24
|
}
|
|
23
|
-
|
|
24
|
-
|
|
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,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1leHBhbmQtcmVwZWF0ZXItYWRhcHRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC9zcmMvbGliL21vZHVsZXMvdGV4dC1leHBhbmQtcmVwZWF0ZXIvdGV4dC1leHBhbmQtcmVwZWF0ZXItYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUVMLFVBQVUsRUFFVixnQkFBZ0IsR0FDakIsTUFBTSxlQUFlLENBQUM7O0FBRXZCOztHQUVHO0FBRUgsTUFBTSxPQUFPLG1DQUFtQztJQUc5QyxZQUFZLGVBQWlDO1FBRjdDLGdFQUFxQjtRQUduQix1QkFBQSxJQUFJLGlEQUFhLGVBQWUsQ0FBQyxjQUFjLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxNQUFBLENBQUM7SUFDbkUsQ0FBQztJQUVNLFFBQVEsQ0FBQyxLQUFpQjtRQUMvQixPQUFRLEtBQUssQ0FBQyxhQUE2QixDQUFDLGdCQUFnQixDQUMxRCxnQ0FBZ0MsQ0FDTixDQUFDO0lBQy9CLENBQUM7SUFFTSxRQUFRLENBQUMsSUFBaUI7UUFDL0IsdUJBQUEsSUFBSSxxREFBVSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFTSxRQUFRLENBQUMsSUFBaUI7UUFDL0IsdUJBQUEsSUFBSSxxREFBVSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVNLGtCQUFrQixDQUFDLFdBQXVCO1FBQy9DLE9BQU8sV0FBVyxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUM7SUFDaEQsQ0FBQztJQUVNLHdCQUF3QixDQUFDLFdBQXVCO1FBQ3JELHVCQUFBLElBQUkscURBQVUsQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUFDLGFBQWEsRUFBRSxZQUFZLENBQUMsQ0FBQztJQUN0RSxDQUFDOzs7Z0lBM0JVLG1DQUFtQztvSUFBbkMsbUNBQW1DOzJGQUFuQyxtQ0FBbUM7a0JBRC9DLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBFbGVtZW50UmVmLFxuICBJbmplY3RhYmxlLFxuICBSZW5kZXJlcjIsXG4gIFJlbmRlcmVyRmFjdG9yeTIsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2t5VGV4dEV4cGFuZFJlcGVhdGVyQWRhcHRlclNlcnZpY2Uge1xuICAjcmVuZGVyZXI6IFJlbmRlcmVyMjtcblxuICBjb25zdHJ1Y3RvcihyZW5kZXJlckZhY3Rvcnk6IFJlbmRlcmVyRmFjdG9yeTIpIHtcbiAgICB0aGlzLiNyZW5kZXJlciA9IHJlbmRlcmVyRmFjdG9yeS5jcmVhdGVSZW5kZXJlcih1bmRlZmluZWQsIG51bGwpO1xuICB9XG5cbiAgcHVibGljIGdldEl0ZW1zKGVsUmVmOiBFbGVtZW50UmVmKTogTm9kZUxpc3RPZjxIVE1MRWxlbWVudD4ge1xuICAgIHJldHVybiAoZWxSZWYubmF0aXZlRWxlbWVudCBhcyBIVE1MRWxlbWVudCkucXVlcnlTZWxlY3RvckFsbChcbiAgICAgICcuc2t5LXRleHQtZXhwYW5kLXJlcGVhdGVyLWl0ZW0nXG4gICAgKSBhcyBOb2RlTGlzdE9mPEhUTUxFbGVtZW50PjtcbiAgfVxuXG4gIHB1YmxpYyBoaWRlSXRlbShpdGVtOiBIVE1MRWxlbWVudCk6IHZvaWQge1xuICAgIHRoaXMuI3JlbmRlcmVyLnNldFN0eWxlKGl0ZW0sICdkaXNwbGF5JywgJ25vbmUnKTtcbiAgfVxuXG4gIHB1YmxpYyBzaG93SXRlbShpdGVtOiBIVE1MRWxlbWVudCk6IHZvaWQge1xuICAgIHRoaXMuI3JlbmRlcmVyLnJlbW92ZVN0eWxlKGl0ZW0sICdkaXNwbGF5Jyk7XG4gIH1cblxuICBwdWJsaWMgZ2V0Q29udGFpbmVySGVpZ2h0KGNvbnRhaW5lckVsOiBFbGVtZW50UmVmKTogbnVtYmVyIHtcbiAgICByZXR1cm4gY29udGFpbmVyRWwubmF0aXZlRWxlbWVudC5vZmZzZXRIZWlnaHQ7XG4gIH1cblxuICBwdWJsaWMgcmVtb3ZlQ29udGFpbmVyTWF4SGVpZ2h0KGNvbnRhaW5lckVsOiBFbGVtZW50UmVmKTogdm9pZCB7XG4gICAgdGhpcy4jcmVuZGVyZXIucmVtb3ZlU3R5bGUoY29udGFpbmVyRWwubmF0aXZlRWxlbWVudCwgJ21heC1oZWlnaHQnKTtcbiAgfVxufVxuIl19
|