@salesforcedevs/dx-components 1.3.194-langpicker2-alpha → 1.3.194-langpicker3-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 CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@salesforcedevs/dx-components",
3
- "version": "1.3.194-langpicker2-alpha",
3
+ "version": "1.3.194-langpicker3-alpha",
4
4
  "description": "DX Lightning web components",
5
5
  "license": "MIT",
6
6
  "engines": {
@@ -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="header_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
- }
@@ -136,6 +136,19 @@ dx-tree:last-child {
136
136
  white-space: nowrap;
137
137
  }
138
138
 
139
+ .footer-nav {
140
+ display: flex;
141
+ padding: 0 var(--dx-g-spacing-sm) 0 var(--dx-g-spacing-2xl);
142
+ position: fixed;
143
+ bottom: 0;
144
+ left: 0;
145
+ width: inherit;
146
+ background: white;
147
+ border-top: 1px solid var(--dx-g-gray-90);
148
+ border-right: 1px solid var(--dx-g-gray-90);
149
+ line-height: var(--dx-g-spacing-xl);
150
+ }
151
+
139
152
  @media screen and (max-width: 768px) {
140
153
  .padding-horizontal {
141
154
  padding-left: var(--dx-g-spacing-lg);