comand-component-library 4.1.92 → 4.1.93
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/dist/comand-component-library.js +4064 -3819
- package/dist/style.css +1 -1
- package/package.json +2 -3
- package/src/ComponentLibrary.vue +111 -33
- package/src/assets/data/smart-search.json +28 -0
- package/src/componentSettingsDataAndControls.vue +1 -1
- package/src/components/CmdFlexibleScrollContainer.vue +41 -0
- package/src/components/CmdFormElement.vue +18 -20
- package/src/components/CmdInnerLink.vue +14 -5
- package/src/components/CmdLink.vue +10 -4
- package/src/components/CmdListOfLinks.vue +4 -0
- package/src/components/CmdListOfLinksItem.vue +4 -0
- package/src/components/CmdSmartSearch.vue +135 -0
- package/src/utils/string.js +2 -10
package/src/ComponentLibrary.vue
CHANGED
@@ -314,7 +314,7 @@
|
|
314
314
|
v-bind="{useCustomTooltip: false}"
|
315
315
|
/>
|
316
316
|
</div>
|
317
|
-
<
|
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
|
-
<
|
431
|
-
|
432
|
-
|
433
|
-
|
434
|
-
|
435
|
-
|
436
|
-
|
437
|
-
|
438
|
-
|
439
|
-
|
440
|
-
|
441
|
-
|
442
|
-
|
443
|
-
|
444
|
-
|
445
|
-
|
446
|
-
|
447
|
-
|
448
|
-
|
449
|
-
|
450
|
-
|
451
|
-
|
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™</h2>
|
@@ -1445,7 +1498,7 @@
|
|
1445
1498
|
ref="CmdHeadline"
|
1446
1499
|
headlineLevel="3"
|
1447
1500
|
>
|
1448
|
-
Headline text<br
|
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
|
-
|
2566
|
+
f(event) {
|
2489
2567
|
event.originalEvent.preventDefault()
|
2490
2568
|
console.log(event)
|
2491
2569
|
},
|
@@ -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
|
+
}
|
@@ -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
|
-
|
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
|
-
|
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
|
-
|
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
|
-
|
1040
|
-
|
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
|
-
<
|
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
|
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
|
17
|
+
* displayed icon
|
16
18
|
*/
|
17
19
|
icon: {
|
18
20
|
type: Object,
|
19
|
-
|
21
|
+
required: false
|
20
22
|
},
|
21
23
|
/**
|
22
24
|
* displayed text
|
23
25
|
*/
|
24
26
|
text: {
|
25
27
|
type: String,
|
26
|
-
|
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'"
|
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(
|
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>
|