comand-component-library 4.1.92 → 4.1.94

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.
@@ -314,7 +314,7 @@
314
314
  v-bind="{useCustomTooltip: false}"
315
315
  />
316
316
  </div>
317
- <h2>Inputfields in Columns</h2>
317
+ <h3>Inputfields in Columns</h3>
318
318
  <div class="flex-container">
319
319
  <CmdFormElement
320
320
  element="input"
@@ -427,29 +427,37 @@
427
427
  :status="validationStatus"
428
428
  :disabled="disabledStatus"
429
429
  />
430
- <CmdFormElement
431
- element="input"
432
- labelText="Label (inline) for inputfield (search) without search-button:"
433
- :displayLabelInline="true"
434
- type="search"
435
- id="inputfield-search-without-searchbutton"
436
- placeholder="Keyword(s)"
437
- v-model="inputSearch"
438
- :showSearchButton="false"
439
- :status="validationStatus"
440
- :disabled="disabledStatus"
441
- />
442
- <CmdFormElement
443
- element="input"
444
- labelText="Label (inline) for inputfield (search):"
445
- :displayLabelInline="true"
446
- type="search"
447
- id="inputfield-search-with-searchbutton"
448
- placeholder="Keyword(s)"
449
- v-model="inputSearch"
450
- :status="validationStatus"
451
- :disabled="disabledStatus"
452
- />
430
+ <h3>Searchfields</h3>
431
+ <div class="flex-container">
432
+ <CmdFormElement
433
+ element="input"
434
+ labelText="Label for inputfield (search) without search-button:"
435
+ type="search"
436
+ id="inputfield-search-without-searchbutton"
437
+ placeholder="Keyword(s)"
438
+ v-model="inputSearch"
439
+ :showSearchButton="false"
440
+ :status="validationStatus"
441
+ :disabled="disabledStatus"
442
+ />
443
+ <CmdFormElement
444
+ element="input"
445
+ labelText="Label for inputfield (search):"
446
+ type="search"
447
+ id="inputfield-search-with-searchbutton"
448
+ placeholder="Keyword(s)"
449
+ v-model="inputSearch"
450
+ :status="validationStatus"
451
+ :disabled="disabledStatus"
452
+ />
453
+ <!-- begin CmdSmartSearch -->
454
+ <CmdSmartSearch
455
+ v-bind="smartSearchData"
456
+ :disabled="disabledStatus"
457
+ />
458
+ <!-- end CmdSmartSearch -->
459
+ </div>
460
+ <h3>Textarea</h3>
453
461
  <CmdFormElement
454
462
  element="textarea"
455
463
  labelText="Label for textarea:"
@@ -1414,6 +1422,51 @@
1414
1422
  </CmdWidthLimitationWrapper>
1415
1423
  <!-- end fancybox --------------------------------------------------------------------------------------------------->
1416
1424
 
1425
+ <!-- begin flexible-scroll-container --------------------------------------------------------------------------------------------------->
1426
+ <CmdWidthLimitationWrapper>
1427
+ <h2 class="headline-demopage" id="section-flexible-scroll-container">Flexible Scroll-Container</h2>
1428
+ <CmdFlexibleScrollContainer style="border: 1px dotted gray">
1429
+ <template v-slot:fixed-wrapper>
1430
+ <div class="default-padding" style="border: 1px dotted gray">
1431
+ Fixed content
1432
+ </div>
1433
+ </template>
1434
+ <template v-slot:scroll-wrapper>
1435
+ <div class="default-padding" style="border: 1px dotted gray">
1436
+ <ul>
1437
+ <li>Dynamic Content</li>
1438
+ <li>Dynamic Content</li>
1439
+ <li>Dynamic Content</li>
1440
+ <li>Dynamic Content</li>
1441
+ <li>Dynamic Content</li>
1442
+ <li>Dynamic Content</li>
1443
+ <li>Dynamic Content</li>
1444
+ <li>Dynamic Content</li>
1445
+ <li>Dynamic Content</li>
1446
+ <li>Dynamic Content</li>
1447
+ <li>Dynamic Content</li>
1448
+ <li>Dynamic Content</li>
1449
+ <li>Dynamic Content</li>
1450
+ <li>Dynamic Content</li>
1451
+ <li>Dynamic Content</li>
1452
+ <li>Dynamic Content</li>
1453
+ <li>Dynamic Content</li>
1454
+ <li>Dynamic Content</li>
1455
+ <li>Dynamic Content</li>
1456
+ <li>Dynamic Content</li>
1457
+ <li>Dynamic Content</li>
1458
+ <li>Dynamic Content</li>
1459
+ <li>Dynamic Content</li>
1460
+ <li>Dynamic Content</li>
1461
+ </ul>
1462
+ </div>
1463
+ </template>
1464
+ </CmdFlexibleScrollContainer>
1465
+ </CmdWidthLimitationWrapper>
1466
+ <!-- end flexible-scroll-container --------------------------------------------------------------------------------------------------->
1467
+
1468
+ <!-- end fancybox --------------------------------------------------------------------------------------------------->
1469
+
1417
1470
  <!-- begin google-maps --------------------------------------------------------------------------------------------------->
1418
1471
  <CmdWidthLimitationWrapper>
1419
1472
  <h2 class="headline-demopage" id="section-google-maps">Google Maps&trade;</h2>
@@ -1445,7 +1498,7 @@
1445
1498
  ref="CmdHeadline"
1446
1499
  headlineLevel="3"
1447
1500
  >
1448
- Headline text<br /> with html given by slot
1501
+ Headline text<br/> with html given by slot
1449
1502
  </CmdHeadline>
1450
1503
 
1451
1504
  </CmdWidthLimitationWrapper>
@@ -1540,6 +1593,7 @@
1540
1593
  ref="CmdLink"
1541
1594
  v-bind="cmdLinkSettingsData"
1542
1595
  :icon="{iconClass: 'icon-chevron-one-stripe-right', position: 'right', tooltip: 'Tooltip for hyperlink'}"
1596
+ @click="cmdLinkOutput"
1543
1597
  />
1544
1598
  <CmdLink
1545
1599
  linkType="href"
@@ -1567,6 +1621,11 @@
1567
1621
  :fancybox="true"
1568
1622
  :icon="{iconClass: 'icon-chevron-one-stripe-right', position: 'right', tooltip: 'Tooltip for hyperlink'}"
1569
1623
  />
1624
+ <dl class="output">
1625
+ <dt>Event:</dt><dd>{{outputCmdLink?.event?.originalEvent.originalEvent}}</dd>
1626
+ <dt>Target:</dt><dd>{{outputCmdLink?.event?.originalEvent.target}}</dd>
1627
+ <dt>LinkType:</dt><dd>{{outputCmdLink?.event?.originalEvent.linkType}}</dd>
1628
+ </dl>
1570
1629
  </CmdWidthLimitationWrapper>
1571
1630
  <!-- end link --------------------------------------------------------------------------------------------------->
1572
1631
 
@@ -1581,7 +1640,13 @@
1581
1640
  ref="CmdListOfLinks"
1582
1641
  v-bind="cmdListOfLinksSettingsData"
1583
1642
  :links="listOfLinksData"
1643
+ @click="cmdLinkOutput"
1584
1644
  />
1645
+ <dl class="output">
1646
+ <dt>Event:</dt><dd>{{outputCmdLink?.event?.originalEvent}}</dd>
1647
+ <dt>Target:</dt><dd>{{outputCmdLink?.event?.originalEvent.target}}</dd>
1648
+ <dt>LinkType:</dt><dd>{{outputCmdLink?.event?.linkType}}</dd>
1649
+ </dl>
1585
1650
  </CmdWidthLimitationWrapper>
1586
1651
  <!-- end list-of-links --------------------------------------------------------------------------------------------------->
1587
1652
 
@@ -1859,7 +1924,7 @@
1859
1924
  :languages="languagesData"
1860
1925
  @click="updateLanguage"
1861
1926
  />
1862
- <p>Selected language: {{selectedLanguage}} </p>
1927
+ <p>Selected language: {{ selectedLanguage }} </p>
1863
1928
  </CmdWidthLimitationWrapper>
1864
1929
  <!-- end switch-language --------------------------------------------------------------------------------------------------->
1865
1930
 
@@ -1992,10 +2057,10 @@
1992
2057
  <a href="#" class="button small icon-cog" title="Open Component Settings"
1993
2058
  @click.prevent="openSettingsSidebar('CmdThumbnailScroller')"></a>
1994
2059
  </h2>
1995
- <p> date (YMD/default): {{formatDate('2025-01-28', "", "-")}}</p>
1996
- <p> date (DMY): {{formatDate('2025-01-28', "dmy")}}</p>
1997
- <p> date (MDY): {{formatDate('2025-01-28', "mdy", "/")}}</p>
1998
- <p> date (invalid)): {{formatDate('invalid')}}</p>
2060
+ <p> date (YMD/default): {{ formatDate('2025-01-28', "", "-") }}</p>
2061
+ <p> date (DMY): {{ formatDate('2025-01-28', "dmy") }}</p>
2062
+ <p> date (MDY): {{ formatDate('2025-01-28', "mdy", "/") }}</p>
2063
+ <p> date (invalid)): {{ formatDate('invalid') }}</p>
1999
2064
  <div class="inline-size">
2000
2065
  <CmdThumbnailScroller
2001
2066
  ref="CmdThumbnailScroller"
@@ -2183,6 +2248,7 @@ import navigationData from '@/assets/data/main-navigation.json'
2183
2248
  import openingHoursData from '@/assets/data/opening-hours.json'
2184
2249
  import selectOptionsData from '@/assets/data/select-options.json'
2185
2250
  import slideshowData from '@/assets/data/slideshow.json'
2251
+ import smartSearchData from '@/assets/data/smart-search.json'
2186
2252
  import socialNetworksData from '@/assets/data/social-networks-page-by-json.json'
2187
2253
  import tabsData from '@/assets/data/tabs.json'
2188
2254
  import tableDataSmall from '@/assets/data/table-small.json'
@@ -2343,6 +2409,12 @@ export default {
2343
2409
  openLeftSidebar: true,
2344
2410
  openRightSidebar: false,
2345
2411
  openBoxes: [1],
2412
+ outputCmdLink: {
2413
+ event: {
2414
+ originalEvent: {},
2415
+ linkType: ""
2416
+ }
2417
+ },
2346
2418
 
2347
2419
  // assign data from json files to data-properties
2348
2420
  addressData,
@@ -2370,6 +2442,7 @@ export default {
2370
2442
  openingHoursData,
2371
2443
  selectOptionsData,
2372
2444
  slideshowData,
2445
+ smartSearchData,
2373
2446
  socialNetworksData,
2374
2447
  tableDataSmall,
2375
2448
  tableDataLarge,
@@ -2385,17 +2458,18 @@ export default {
2385
2458
  },
2386
2459
  computed: {
2387
2460
  navigationDataModified() {
2388
- if(!this.useRouterLinks) {
2461
+ if (!this.useRouterLinks) {
2389
2462
  function mapLinkTypes(navigationEntries) {
2390
2463
  return navigationEntries.map((item) => {
2391
2464
  item.type = "href"
2392
2465
 
2393
- if(item.subentries?.length) {
2466
+ if (item.subentries?.length) {
2394
2467
  item.subentries = mapLinkTypes(item.subentries)
2395
2468
  }
2396
2469
  return item
2397
2470
  })
2398
2471
  }
2472
+
2399
2473
  return mapLinkTypes(this.navigationData.navigationEntries)
2400
2474
  }
2401
2475
  return this.navigationData.navigationEntries
@@ -2414,6 +2488,10 @@ export default {
2414
2488
  }
2415
2489
  },
2416
2490
  methods: {
2491
+ cmdLinkOutput(event, linkType) {
2492
+ this.outputCmdLink.event.originalEvent = event
2493
+ this.outputCmdLink.event.linkType = linkType
2494
+ },
2417
2495
  formatDate,
2418
2496
  updateLanguage(event) {
2419
2497
  this.selectedLanguage = event.iso2
@@ -2485,7 +2563,7 @@ export default {
2485
2563
  return navigationData
2486
2564
  }, 1000);
2487
2565
  },
2488
- clickOnListOfLinks(event) {
2566
+ f(event) {
2489
2567
  event.originalEvent.preventDefault()
2490
2568
  console.log(event)
2491
2569
  },
@@ -10,6 +10,7 @@
10
10
  "CookieDisclaimer",
11
11
  "Forms",
12
12
  "Fancybox",
13
+ "FlexibleScrollContainer",
13
14
  "GoogleMaps",
14
15
  "Headlines",
15
16
  "Icons",
@@ -0,0 +1,28 @@
1
+ {
2
+ "listOfRecommendations": [
3
+ {
4
+ "linkType": "href",
5
+ "text": "Option #1",
6
+ "icon": {
7
+ "iconClass": "icon-home"
8
+ }
9
+ },
10
+ {
11
+ "linkType": "href",
12
+ "text": "Option #2",
13
+ "icon": {
14
+ "iconClass": "icon-company"
15
+ }
16
+ },
17
+ {
18
+ "linkType": "href",
19
+ "text": "Option #3",
20
+ "icon": {
21
+ "iconClass": "icon-globe"
22
+ }
23
+ }
24
+ ],
25
+ "cmdFormElement": {
26
+ "labelText": "Label for inputfield (search) with smart-search:"
27
+ }
28
+ }
@@ -457,7 +457,7 @@ data() {
457
457
  headlineText: "Send Login",
458
458
  headlineLevel: 4
459
459
  },
460
- orientation: "horizontal",
460
+ orientation: "horizontal"
461
461
  },
462
462
  cmdLoginFormSettingsControls: {
463
463
  orientation: [
@@ -0,0 +1,41 @@
1
+ <template>
2
+ <div :class="['cmd-flexible-scroll-container flexible-scroll-container', {'reverse-order': fixedContainerAtBottom}]">
3
+ <div class="fixed-wrapper">
4
+ <!-- begin slot for fixed-wrapper -->
5
+ <slot name="fixed-wrapper"></slot>
6
+ <!-- end slot for fixed-wrapper -->
7
+ </div>
8
+ <div class="scroll-wrapper">
9
+ <!-- begin slot for scroll-wrapper -->
10
+ <slot name="scroll-wrapper"></slot>
11
+ <!-- end slot for scroll-wrapper -->
12
+ </div>
13
+ </div>
14
+ </template>
15
+
16
+ <script>
17
+ export default {
18
+ name: "CmdFlexibleScrollContainer",
19
+ /**
20
+ * put fixed container to bottom
21
+ *
22
+ * @affectLayout: true
23
+ */
24
+ props: {
25
+ fixedContainerAtBottom: {
26
+ type: Boolean,
27
+ default: false
28
+ }
29
+ }
30
+ }
31
+ </script>
32
+
33
+ <style>
34
+ /* begin cmd-flexible-scroll-container ------------------------------------------------------------------------------------------ */
35
+ .cmd-flexible-scroll-container {
36
+ &.reverse-order {
37
+ flex-direction: column-reverse;
38
+ }
39
+ }
40
+ /* end cmd-flexible-scroll-container ------------------------------------------------------------------------------------------ */
41
+ </style>
@@ -179,27 +179,27 @@
179
179
  @blur="onBlur"
180
180
  @change="$emit('update:modelValue', $event.target.value)">
181
181
 
182
- <option v-if="!groupSelectOptionsByInitialLetters"
182
+ <option v-if="!groupSelectOptionsByInitialLetters"
183
183
  v-for="(option, index) in selectOptions"
184
184
  :key="index"
185
185
  :value="option.value"
186
186
  :selected="option.value === modelValue"
187
+ >
188
+ {{ option.text }}
189
+ </option>
190
+ <optgroup v-else :label="key"
191
+ v-for="(options, key) in initialLetters"
192
+ :key="key"
193
+ >
194
+ <option
195
+ v-for="(option, optionIndex) in options"
196
+ :key="optionIndex"
197
+ :value="option.value"
198
+ :selected="option.value === modelValue"
187
199
  >
188
200
  {{ option.text }}
189
201
  </option>
190
- <optgroup v-else :label="key"
191
- v-for="(options, key) in initialLetters"
192
- :key="key"
193
- >
194
- <option
195
- v-for="(option, optionIndex) in options"
196
- :key="optionIndex"
197
- :value="option.value"
198
- :selected="option.value === modelValue"
199
- >
200
- {{ option.text }}
201
- </option>
202
- </optgroup>
202
+ </optgroup>
203
203
  </select>
204
204
  <!-- end selectbox -->
205
205
 
@@ -700,7 +700,7 @@ export default {
700
700
  },
701
701
  computed: {
702
702
  initialLetters() {
703
- return this.getInitialLetters(this.selectOptions)
703
+ return this.getInitialLetters(this.selectOptions)
704
704
  },
705
705
  elementAttributes() {
706
706
  const commonAttributes = ["name", "required", "readonly", "disabled", "autofocus"]
@@ -789,7 +789,7 @@ export default {
789
789
  listOfOptions.sort((a, b) => a.text.toLowerCase().localeCompare(b.text.toLowerCase()))
790
790
 
791
791
  for (let i = 0; i < listOfOptions.length; i++) {
792
- const initialLetter = listOfOptions[i].text.slice(0,1)
792
+ const initialLetter = listOfOptions[i].text.slice(0, 1)
793
793
  if (!groupedListOfOptions[initialLetter]) {
794
794
  groupedListOfOptions[initialLetter] = []
795
795
  }
@@ -1036,10 +1036,8 @@ export default {
1036
1036
  }
1037
1037
 
1038
1038
  .place-inside {
1039
- + .search-field-wrapper {
1040
- input {
1041
- padding-left: calc(var(--default-padding) * 3);
1042
- }
1039
+ input {
1040
+ padding-left: calc(var(--default-padding) * 3);
1043
1041
  }
1044
1042
  }
1045
1043
 
@@ -1,7 +1,9 @@
1
1
  <template>
2
- <span v-if="icon.iconClass && icon.position === 'left' || icon.position === 'top' || !icon.position" :class="icon.iconClass" :title="icon.tooltip"></span>
2
+ <img v-if="image?.src && (image?.position === 'left' || image?.position === 'top' || !image?.position)" :src="image?.src" :alt="image?.alt" />
3
+ <span v-if="icon?.iconClass && (icon?.position === 'left' || icon?.position === 'top' || !icon?.position)" :class="icon?.iconClass" :title="icon?.tooltip"></span>
3
4
  <span v-if="text">{{ text }}</span>
4
- <span v-if="icon.iconClass && icon.position === 'right' || icon.position === 'bottom'" :class="icon.iconClass" :title="icon.tooltip"></span>
5
+ <span v-if="icon?.iconClass && (icon?.position === 'right' || icon?.position === 'bottom')" :class="icon?.iconClass" :title="icon?.tooltip"></span>
6
+ <img v-if="image?.src && (image?.position === 'right' || image?.position === 'bottom' || !image?.position)" :src="imag?.src" :alt="image?.alt" />
5
7
  <!-- begin default-slot -->
6
8
  <slot></slot>
7
9
  <!-- end default-slot -->
@@ -12,18 +14,25 @@ export default {
12
14
  name: "CmdInnerLink",
13
15
  props: {
14
16
  /**
15
- * icon to display
17
+ * displayed icon
16
18
  */
17
19
  icon: {
18
20
  type: Object,
19
- default: {}
21
+ required: false
20
22
  },
21
23
  /**
22
24
  * displayed text
23
25
  */
24
26
  text: {
25
27
  type: String,
26
- default: ""
28
+ required: false
29
+ },
30
+ /**
31
+ * displayed image
32
+ */
33
+ image: {
34
+ type: Object,
35
+ required: false
27
36
  }
28
37
  }
29
38
  }
@@ -1,20 +1,26 @@
1
1
  <template>
2
2
  <!-- begin CmdLink -->
3
3
  <!-- begin href -->
4
- <a v-if="linkType === 'href'" :href="path" :target="target" :class="['cmd-link', {'button': styleAsButton, 'primary': primaryButton, 'box': styleAsBox, 'fancybox': fancybox}]" @click="emitClick($event, 'href')" :title="icon?.tooltip">
4
+ <a v-if="linkType === 'href'"
5
+ :href="path"
6
+ :target="target"
7
+ :class="['cmd-link', {'button': styleAsButton, 'primary': primaryButton, 'box': styleAsBox, 'fancybox': fancybox}]"
8
+ @click.prevent="emitClick($event, 'href')"
9
+ :title="icon?.tooltip"
10
+ >
5
11
  <CmdInnerLink :text="text" :icon="icon">
6
12
  <slot></slot>
7
13
  </CmdInnerLink>
8
14
  </a>
9
15
  <!-- end href -->
10
16
 
11
- <!-- begin router -->
17
+ <!-- begin router-link -->
12
18
  <router-link v-else-if="linkType === 'router'" :to="path" :class="['cmd-link', {'button': styleAsButton, 'primary': primaryButton, 'box': styleAsBox, 'fancybox': fancybox}]" @click="emitClick($event, 'router')" :title="icon?.tooltip">
13
19
  <CmdInnerLink :text="text" :icon="icon">
14
20
  <slot></slot>
15
21
  </CmdInnerLink>
16
22
  </router-link>
17
- <!-- end router -->
23
+ <!-- end router-link -->
18
24
 
19
25
  <!-- begin button -->
20
26
  <button v-else-if="linkType === 'button'" :class="['cmd-link button', {'primary': primaryButton, 'box': styleAsBox, 'fancybox': fancybox}]" type="submit" @click="emitClick($event, 'button')" :title="icon?.tooltip">
@@ -112,7 +118,7 @@ export default {
112
118
  },
113
119
  methods: {
114
120
  emitClick(event, linkType) {
115
- this.$emit('click', {originalEvent: event, linkType: linkType})
121
+ this.$emit("click", {originalEvent: event, linkType: linkType})
116
122
  }
117
123
  }
118
124
  }
@@ -23,6 +23,7 @@
23
23
  :key="index"
24
24
  :class="{'active': sectionAnchors && activeSection === index}"
25
25
  :link="link"
26
+ @click="emitClick($event, linkType)"
26
27
  />
27
28
  <!-- end CmdListOfLinksItem-->
28
29
 
@@ -199,6 +200,9 @@ export default {
199
200
  }
200
201
  }
201
202
  })
203
+ },
204
+ emitClick(event, linkType) {
205
+ this.$emit("click", {originalEvent: event, linkType: linkType})
202
206
  }
203
207
  }
204
208
  }
@@ -14,6 +14,7 @@
14
14
  :styleAsButton="link?.styleAsButton"
15
15
  :primaryButton="link?.primaryButton"
16
16
  :styleAsBox="link?.styleAsBox"
17
+ @click="emitClick($event, linkType)"
17
18
  />
18
19
  <!-- end CmdLink -->
19
20
 
@@ -78,6 +79,9 @@ export default {
78
79
  props.text = text
79
80
  }
80
81
  })
82
+ },
83
+ emitClick(event, linkType) {
84
+ this.$emit("click", {originalEvent: event, linkType: linkType})
81
85
  }
82
86
  }
83
87
  }
@@ -0,0 +1,135 @@
1
+ <template>
2
+ <div class="cmd-smart-search">
3
+ <!-- begin CmdFormElement -->
4
+ <CmdFormElement
5
+ element="input"
6
+ type="search"
7
+ v-bind="cmdFormElementOptions"
8
+ v-model="searchTerm"
9
+ @input="showRecommendations"
10
+ />
11
+ <!-- end CmdFormElement -->
12
+
13
+ <!-- begin list-of-recommendations -->
14
+ <ul v-if="showListOfRecommmendations" class="list-of-recommendations no-list-items">
15
+ <li v-for="(item, index) in listOfRecommendations" :key="index">
16
+ <!-- begin CmdLink -->
17
+ <CmdLink v-bind="item" @click="optionSelected" />
18
+ <!-- end CmdLink -->
19
+ </li>
20
+ </ul>
21
+ <!-- end list-of-recommendations -->
22
+ </div>
23
+ </template>
24
+
25
+ <script>
26
+ export default {
27
+ name: "CmdSmartSearch",
28
+ data() {
29
+ return {
30
+ showListOfRecommmendations: false,
31
+ searchTerm: ""
32
+ }
33
+ },
34
+ props: {
35
+ /**
36
+ * set default v-model (must be named modelValue in Vue3)
37
+ */
38
+ modelValue: {
39
+ type: [String, Number],
40
+ default: ""
41
+ },
42
+ /**
43
+ * provide list for recommendations shown below search-field
44
+ */
45
+ listOfRecommendations: {
46
+ type: Array,
47
+ required: true
48
+ },
49
+ /**
50
+ * define search-field
51
+ */
52
+ cmdFormElement: {
53
+ type: Object,
54
+ required: false
55
+ }
56
+ },
57
+ computed: {
58
+ cmdFormElementOptions() {
59
+ return {
60
+ labelText: "Search",
61
+ placeholder: "Enter Keyword(s)",
62
+ showSearchButton: false,
63
+ ...this.cmdFormElement
64
+ }
65
+ }
66
+ },
67
+ methods: {
68
+ showRecommendations() {
69
+ this.showListOfRecommmendations = true
70
+ },
71
+ optionSelected(event) {
72
+ event.originalEvent.preventDefault()
73
+ this.showListOfRecommmendations = false
74
+ console.log("event", event)
75
+ this.searchTerm = event.target.value // set search-field to selected option
76
+ this.$emit("update:modelValue", this.searchTerm)
77
+ }
78
+ },
79
+ watch: {
80
+ searchTerm() {
81
+ if(this.searchTerm.length) {
82
+ this.showRecommendations()
83
+ } else {
84
+ this.showListOfRecommmendations = false
85
+ }
86
+ }
87
+ }
88
+ }
89
+ </script>
90
+
91
+ <style>
92
+ .cmd-smart-search {
93
+ .list-of-recommendations {
94
+ display: flex;
95
+ flex-direction: column;
96
+ border: var(--default-border);
97
+ border-top: 0;
98
+ background: var(--default-background);
99
+ border-bottom-left-radius: var(--default-border-radius);
100
+ border-bottom-right-radius: var(--default-border-radius);
101
+
102
+ li {
103
+ &:not(:last-child) {
104
+ border-bottom: var(--default-border);
105
+ }
106
+
107
+ &:last-child {
108
+ border-bottom-left-radius: inherit;
109
+ border-bottom-right-radius: inherit;
110
+
111
+ a {
112
+ border-bottom-left-radius: inherit;
113
+ border-bottom-right-radius: inherit;
114
+ }
115
+ }
116
+
117
+ a {
118
+ display: flex;
119
+ align-items: center;
120
+ padding: var(--default-padding);
121
+ text-decoration: none;
122
+ width: 100%;
123
+
124
+ &:hover, &:active, &:focus {
125
+ background: var(--hyperlink-color);
126
+
127
+ span, span[class*="icon"] {
128
+ color: var(--pure-white);
129
+ }
130
+ }
131
+ }
132
+ }
133
+ }
134
+ }
135
+ </style>