summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorDaniel Kesselberg <mail@danielkesselberg.de>2023-10-11 16:20:09 +0200
committerDaniel Kesselberg <mail@danielkesselberg.de>2023-10-11 16:53:52 +0200
commit1910947e55f40cee0bf530531309bb8460f2665b (patch)
tree7b8f33873ecfb46b500e537a9e7b8a83ab22f3dc /src
parent106bd3bf5ce055160ca2087d09aed48c5bdae83f (diff)
refactor: move type matching to own function
Signed-off-by: Daniel Kesselberg <mail@danielkesselberg.de>
Diffstat (limited to 'src')
-rw-r--r--src/components/ContactDetails/ContactDetailsProperty.vue28
-rw-r--r--src/utils/matchTypes.d.ts36
-rw-r--r--src/utils/matchTypes.ts50
3 files changed, 91 insertions, 23 deletions
diff --git a/src/components/ContactDetails/ContactDetailsProperty.vue b/src/components/ContactDetails/ContactDetailsProperty.vue
index 552629cf..ca80cf59 100644
--- a/src/components/ContactDetails/ContactDetailsProperty.vue
+++ b/src/components/ContactDetails/ContactDetailsProperty.vue
@@ -55,6 +55,7 @@ import PropertyText from '../Properties/PropertyText.vue'
import PropertyMultipleText from '../Properties/PropertyMultipleText.vue'
import PropertyDateTime from '../Properties/PropertyDateTime.vue'
import PropertySelect from '../Properties/PropertySelect.vue'
+import { matchTypes } from '../../utils/matchTypes.ts'
export default {
name: 'ContactDetailsProperty',
@@ -246,29 +247,10 @@ export default {
// we only use uppercase strings
.map(str => str.toUpperCase())
- // Compare array and score them by how many matches they have to the selected type
- // sorting directly is cleaner but slower
- // https://jsperf.com/array-map-and-intersection-perf
- const matchingTypes = this.propModel.options
- .map(type => {
- let score = 0
- const types = type.id.split(',') // "WORK,HOME" => ['WORK', 'HOME']
-
- if (types.length === selectedType.length) {
- // additional point for same length
- score++
- }
-
- const intersection = types.filter(value => selectedType.includes(value))
- score = score + intersection.length
-
- return { type, score }
- })
-
- // Sort by score, filtering out the null score and selecting the first match
- const matchingType = matchingTypes
- .sort((a, b) => b.score - a.score)
- .filter(type => type.score > 0)[0]
+ const matchingType = matchTypes(
+ selectedType,
+ this.propModel.options,
+ )
if (matchingType) {
return matchingType.type
diff --git a/src/utils/matchTypes.d.ts b/src/utils/matchTypes.d.ts
new file mode 100644
index 00000000..18804351
--- /dev/null
+++ b/src/utils/matchTypes.d.ts
@@ -0,0 +1,36 @@
+/**
+ * @copyright Copyright (c) 2023 Daniel Kesselberg <mail@danielkesselberg.de>
+ *
+ * @author Daniel Kesselberg <mail@danielkesselberg.de>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+/**
+ * Match a list of types against the available types
+ *
+ * @param {Array<string>} selectedTypes
+ * @param {Array<{id: string, name: string}>} options
+ */
+export declare function matchTypes(selectedTypes: Array<string>, options: Array<{
+ id: string;
+ name: string;
+}>): {
+ type: {
+ id: string;
+ name: string;
+ };
+ score: number;
+} | undefined;
diff --git a/src/utils/matchTypes.ts b/src/utils/matchTypes.ts
new file mode 100644
index 00000000..d0652192
--- /dev/null
+++ b/src/utils/matchTypes.ts
@@ -0,0 +1,50 @@
+/**
+ * @copyright Copyright (c) 2023 Daniel Kesselberg <mail@danielkesselberg.de>
+ *
+ * @author Daniel Kesselberg <mail@danielkesselberg.de>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+/**
+ * Match a list of types against the available types
+ *
+ * @param {Array<string>} selectedTypes
+ * @param {Array<{id: string, name: string}>} options
+ */
+export function matchTypes(selectedTypes: Array<string>, options: Array<{id: string, name: string}>) {
+ const items = options.map(option => {
+ let score = 0
+ const types = option.id.split(',') // "WORK,HOME" => ['WORK', 'HOME']
+
+ const intersection = types.filter(value => selectedTypes.includes(value))
+ score = score + intersection.length
+
+ if (selectedTypes.length === types.length && selectedTypes.length === intersection.length) {
+ score++
+ }
+
+ return {
+ type: option,
+ score,
+ }
+ })
+
+ return items
+ .filter(value => value.score > 0)
+ .sort((a, b) => b.score - a.score)
+ .shift()
+}