@salesforcedevs/dx-components 1.3.194-langpicker2-alpha → 1.3.194-langpicker7-alpha
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/package.json +1 -1
- package/src/modules/dx/dropdownOption/dropdownOption.css +2 -2
- package/src/modules/dx/sidebar/sidebar.html +21 -0
- package/src/modules/dx/sidebar/sidebar.ts +46 -0
- package/src/modules/dx/sidebarOld/sidebarOld.css +0 -13
- package/src/modules/dx/sidebarOld/sidebarOld.html +8 -17
- package/src/modules/dx/sidebarOld/sidebarOld.ts +4 -23
- package/src/modules/dxHelpers/commonSidebar/commonSidebar.css +43 -1
package/package.json
CHANGED
|
@@ -38,7 +38,7 @@
|
|
|
38
38
|
}
|
|
39
39
|
|
|
40
40
|
.option:active {
|
|
41
|
-
background: var(--dx-g-blue-vibrant-95) !important;
|
|
41
|
+
background: var(--dx-g-cloud-blue-vibrant-95) !important;
|
|
42
42
|
}
|
|
43
43
|
|
|
44
44
|
.option:not(.option-active):hover {
|
|
@@ -46,7 +46,7 @@
|
|
|
46
46
|
}
|
|
47
47
|
|
|
48
48
|
.option-active {
|
|
49
|
-
background: var(--dx-g-blue-vibrant-95);
|
|
49
|
+
background: var(--dx-g-cloud-blue-vibrant-95);
|
|
50
50
|
}
|
|
51
51
|
|
|
52
52
|
.option_details {
|
|
@@ -92,5 +92,26 @@
|
|
|
92
92
|
onselecteditemrendered={onSelectedItemRendered}
|
|
93
93
|
></dx-tree>
|
|
94
94
|
</div>
|
|
95
|
+
|
|
96
|
+
<div if:false={mobile} class="footer-nav">
|
|
97
|
+
<dx-dropdown
|
|
98
|
+
if:true={hasLanguages}
|
|
99
|
+
class="footer_lang-dropdown"
|
|
100
|
+
options={languages}
|
|
101
|
+
small
|
|
102
|
+
value-path={langValuePath}
|
|
103
|
+
value={language}
|
|
104
|
+
onchange={onLangChange}
|
|
105
|
+
>
|
|
106
|
+
<dx-button
|
|
107
|
+
aria-label="Select Language"
|
|
108
|
+
variant="inline"
|
|
109
|
+
icon-size="small"
|
|
110
|
+
icon-symbol="world"
|
|
111
|
+
>
|
|
112
|
+
{languageLabel}
|
|
113
|
+
</dx-button>
|
|
114
|
+
</dx-dropdown>
|
|
115
|
+
</div>
|
|
95
116
|
</div>
|
|
96
117
|
</template>
|
|
@@ -5,6 +5,8 @@ import { getSidebarSearchParams } from "dxUtils/coveo";
|
|
|
5
5
|
import { toJson } from "dxUtils/normalizers";
|
|
6
6
|
import SidebarSearch from "dx/sidebarSearch";
|
|
7
7
|
import { SidebarBase } from "dxBaseElements/sidebarBase";
|
|
8
|
+
import type { OptionWithLink } from "typings/custom";
|
|
9
|
+
import get from "lodash.get";
|
|
8
10
|
|
|
9
11
|
const MOBILE_SIZE_MATCH = "768px";
|
|
10
12
|
|
|
@@ -14,6 +16,7 @@ export default class Sidebar extends SidebarBase {
|
|
|
14
16
|
@api coveoSearchHub!: string;
|
|
15
17
|
@api coveoAdvancedQueryConfig!: string;
|
|
16
18
|
@api header: string = "";
|
|
19
|
+
@api langValuePath: string = "id";
|
|
17
20
|
|
|
18
21
|
@api
|
|
19
22
|
get value() {
|
|
@@ -43,6 +46,26 @@ export default class Sidebar extends SidebarBase {
|
|
|
43
46
|
}));
|
|
44
47
|
}
|
|
45
48
|
|
|
49
|
+
@api
|
|
50
|
+
get languages() {
|
|
51
|
+
return this._languages;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
set languages(value) {
|
|
55
|
+
this._languages = toJson(value);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
@api
|
|
59
|
+
get language() {
|
|
60
|
+
return this._language;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
set language(value) {
|
|
64
|
+
if (this._language !== value) {
|
|
65
|
+
this._language = value;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
46
69
|
@api
|
|
47
70
|
setInputValue(searchTerm: string) {
|
|
48
71
|
(
|
|
@@ -68,6 +91,8 @@ export default class Sidebar extends SidebarBase {
|
|
|
68
91
|
private scrollToSelectedSearchResult: boolean = false;
|
|
69
92
|
private selectedSearchResultIndex: number = -1;
|
|
70
93
|
private requestedFetchMoreResults: boolean = false;
|
|
94
|
+
private _languages!: OptionWithLink[];
|
|
95
|
+
private _language: string | null = null;
|
|
71
96
|
|
|
72
97
|
private get areResultsEmpty(): boolean {
|
|
73
98
|
return (
|
|
@@ -256,4 +281,25 @@ export default class Sidebar extends SidebarBase {
|
|
|
256
281
|
this.template.querySelector("dx-sidebar-search") as any
|
|
257
282
|
)?.requestOpenDropdown(false);
|
|
258
283
|
}
|
|
284
|
+
|
|
285
|
+
private get hasLanguages(): boolean {
|
|
286
|
+
return !!(this.languages && this.languages.length);
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
private get languageLabel(): string {
|
|
290
|
+
return (
|
|
291
|
+
(this.language &&
|
|
292
|
+
this.languages.find(
|
|
293
|
+
(lang) => get(lang, this.langValuePath) === this.language
|
|
294
|
+
)?.label) ||
|
|
295
|
+
this.languages[0].label
|
|
296
|
+
);
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
private onLangChange(event: CustomEvent<string>): void {
|
|
300
|
+
const { detail } = event;
|
|
301
|
+
this._language = detail;
|
|
302
|
+
|
|
303
|
+
this.dispatchEvent(new CustomEvent("langchange", { detail }));
|
|
304
|
+
}
|
|
259
305
|
}
|
|
@@ -24,16 +24,3 @@ dx-empty-state {
|
|
|
24
24
|
.header-toggle-icon dx-button[aria-expanded="true"]:hover {
|
|
25
25
|
--dx-c-button-secondary-color-hover: var(--dx-g-gray-80);
|
|
26
26
|
}
|
|
27
|
-
|
|
28
|
-
.footer-nav {
|
|
29
|
-
display: flex;
|
|
30
|
-
padding: 0 var(--dx-g-spacing-sm) 0 var(--dx-g-spacing-2xl);
|
|
31
|
-
position: fixed;
|
|
32
|
-
bottom: 0;
|
|
33
|
-
left: 0;
|
|
34
|
-
width: inherit;
|
|
35
|
-
background: white;
|
|
36
|
-
border-top: 1px solid var(--dx-g-gray-90);
|
|
37
|
-
border-right: 1px solid var(--dx-g-gray-90);
|
|
38
|
-
line-height: var(--dx-g-spacing-xl);
|
|
39
|
-
}
|
|
@@ -70,24 +70,15 @@
|
|
|
70
70
|
</template>
|
|
71
71
|
|
|
72
72
|
<div if:false={mobile} class="footer-nav">
|
|
73
|
-
<
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
onchange={onLangChange}
|
|
73
|
+
<doc-footer-nav
|
|
74
|
+
class="footer_lang-dropdown"
|
|
75
|
+
lang-value-path={langValuePath}
|
|
76
|
+
language={language}
|
|
77
|
+
languages={languages}
|
|
78
|
+
bail-href={bailHref}
|
|
79
|
+
bail-label={bailLabel}
|
|
81
80
|
>
|
|
82
|
-
|
|
83
|
-
aria-label="Select Language"
|
|
84
|
-
variant="inline"
|
|
85
|
-
icon-size="small"
|
|
86
|
-
icon-symbol="world"
|
|
87
|
-
>
|
|
88
|
-
{languageLabel}
|
|
89
|
-
</dx-button>
|
|
90
|
-
</dx-dropdown>
|
|
81
|
+
</doc-footer-nav>
|
|
91
82
|
</div>
|
|
92
83
|
</div>
|
|
93
84
|
</template>
|
|
@@ -13,6 +13,10 @@ const MOBILE_SIZE_MATCH = "768px";
|
|
|
13
13
|
export default class Sidebar extends SidebarBase {
|
|
14
14
|
@api header: string = "";
|
|
15
15
|
@api langValuePath: string = "id";
|
|
16
|
+
@api languages!: OptionWithLink[];
|
|
17
|
+
@api language!: string;
|
|
18
|
+
@api bailHref!: string;
|
|
19
|
+
@api bailLabel!: string;
|
|
16
20
|
|
|
17
21
|
@api
|
|
18
22
|
get value() {
|
|
@@ -40,26 +44,6 @@ export default class Sidebar extends SidebarBase {
|
|
|
40
44
|
this.assignFilteredTrees();
|
|
41
45
|
}
|
|
42
46
|
|
|
43
|
-
@api
|
|
44
|
-
get languages() {
|
|
45
|
-
return this._languages;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
set languages(value) {
|
|
49
|
-
this._languages = toJson(value);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
@api
|
|
53
|
-
get language() {
|
|
54
|
-
return this._language;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
set language(value) {
|
|
58
|
-
if (this._language !== value) {
|
|
59
|
-
this._language = value;
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
|
|
63
47
|
private expanded: boolean = true;
|
|
64
48
|
private _searchTimeout?: number;
|
|
65
49
|
private _value?: string = undefined;
|
|
@@ -71,9 +55,6 @@ export default class Sidebar extends SidebarBase {
|
|
|
71
55
|
private matchMedia!: MediaQueryList;
|
|
72
56
|
private valueToLabel: { [key: string]: string } = {};
|
|
73
57
|
|
|
74
|
-
private _languages!: OptionWithLink[];
|
|
75
|
-
private _language: string | null = null;
|
|
76
|
-
|
|
77
58
|
private get anyResultMatch() {
|
|
78
59
|
return this.filteredTrees.length > 0;
|
|
79
60
|
}
|
|
@@ -78,10 +78,31 @@ dx-tree:last-child {
|
|
|
78
78
|
box-shadow: 2px 0 0 0 var(--border-color);
|
|
79
79
|
min-height: var(--dx-c-sidebar-min-height);
|
|
80
80
|
padding: var(--dx-c-sidebar-vertical-padding) 0
|
|
81
|
-
var(--dx-c-sidebar-vertical-padding)
|
|
81
|
+
var(--dx-c-sidebar-vertical-padding) 0;
|
|
82
82
|
position: relative;
|
|
83
83
|
}
|
|
84
84
|
|
|
85
|
+
.footer_lang-dropdown {
|
|
86
|
+
--button-primary-color: var(--dx-g-blue-vibrant-50);
|
|
87
|
+
--button-primary-color-hover: var(--dx-g-cloud-blue-vibrant-95);
|
|
88
|
+
|
|
89
|
+
padding: var(--dx-g-spacing-2xs) var(--dx-g-spacing-md);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
.footer_lang-dropdown > dx-button {
|
|
93
|
+
--dx-c-button-primary-color: var(--button-primary-color);
|
|
94
|
+
--dx-c-slot-empty-width: min-content;
|
|
95
|
+
--border-color: var(--button-primary-color);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
.footer_lang-dropdown:hover,
|
|
99
|
+
.footer_lang-dropdown:active,
|
|
100
|
+
.footer_lang-dropdown:focus {
|
|
101
|
+
background-color: var(--button-primary-color-hover);
|
|
102
|
+
|
|
103
|
+
--border-color: var(--button-primary-color-hover);
|
|
104
|
+
}
|
|
105
|
+
|
|
85
106
|
.collapsed.container:not(.container-mobile) {
|
|
86
107
|
background-color: transparent;
|
|
87
108
|
}
|
|
@@ -136,9 +157,30 @@ dx-tree:last-child {
|
|
|
136
157
|
white-space: nowrap;
|
|
137
158
|
}
|
|
138
159
|
|
|
160
|
+
.footer-nav {
|
|
161
|
+
display: flex;
|
|
162
|
+
padding: 0 var(--dx-g-spacing-sm) 0 var(--dx-g-spacing-2xl);
|
|
163
|
+
position: fixed;
|
|
164
|
+
bottom: 0;
|
|
165
|
+
left: 0;
|
|
166
|
+
width: inherit;
|
|
167
|
+
background: white;
|
|
168
|
+
border-top: 1px solid var(--dx-g-gray-90);
|
|
169
|
+
border-right: 1px solid var(--dx-g-gray-90);
|
|
170
|
+
height: var(--dx-g-spacing-xl);
|
|
171
|
+
}
|
|
172
|
+
|
|
139
173
|
@media screen and (max-width: 768px) {
|
|
140
174
|
.padding-horizontal {
|
|
141
175
|
padding-left: var(--dx-g-spacing-lg);
|
|
142
176
|
padding-right: var(--dx-g-spacing-md);
|
|
143
177
|
}
|
|
178
|
+
|
|
179
|
+
.header_l2_group-title .header_lang-dropdown {
|
|
180
|
+
margin-left: auto;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
.header_lang-dropdown > dx-button {
|
|
184
|
+
padding: var(--dx-g-spacing-2xs) 0;
|
|
185
|
+
}
|
|
144
186
|
}
|