mirror of
https://github.com/ae-utbm/sith.git
synced 2025-01-24 16:01:11 +00:00
Merge pull request #989 from ae-utbm/counter
Make code matching rank first in counter click
This commit is contained in:
commit
429df81ec9
@ -3,6 +3,7 @@ import { registerComponent } from "#core:utils/web-components";
|
|||||||
import type { RecursivePartial, TomSettings } from "tom-select/dist/types/types";
|
import type { RecursivePartial, TomSettings } from "tom-select/dist/types/types";
|
||||||
|
|
||||||
const productParsingRegex = /^(\d+x)?(.*)/i;
|
const productParsingRegex = /^(\d+x)?(.*)/i;
|
||||||
|
const codeParsingRegex = / \((\w+)\)$/;
|
||||||
|
|
||||||
function parseProduct(query: string): [number, string] {
|
function parseProduct(query: string): [number, string] {
|
||||||
const parsed = productParsingRegex.exec(query);
|
const parsed = productParsingRegex.exec(query);
|
||||||
@ -21,6 +22,18 @@ export class CounterProductSelect extends AutoCompleteSelectBase {
|
|||||||
|
|
||||||
protected attachBehaviors(): void {
|
protected attachBehaviors(): void {
|
||||||
this.allowMultipleProducts();
|
this.allowMultipleProducts();
|
||||||
|
this.parseCodes();
|
||||||
|
}
|
||||||
|
|
||||||
|
private parseCodes(): void {
|
||||||
|
// We guess the code from the product name so we can prioritize search on it
|
||||||
|
// If no code is found, we just ignore it and everything still is fine
|
||||||
|
for (const option of Object.values(this.widget.options)) {
|
||||||
|
const match = codeParsingRegex.exec(option.text);
|
||||||
|
if (match !== null) {
|
||||||
|
option.code = match[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private allowMultipleProducts(): void {
|
private allowMultipleProducts(): void {
|
||||||
@ -60,6 +73,10 @@ export class CounterProductSelect extends AutoCompleteSelectBase {
|
|||||||
}
|
}
|
||||||
protected tomSelectSettings(): RecursivePartial<TomSettings> {
|
protected tomSelectSettings(): RecursivePartial<TomSettings> {
|
||||||
/* We disable the dropdown on focus because we're going to always autofocus the widget */
|
/* We disable the dropdown on focus because we're going to always autofocus the widget */
|
||||||
return { ...super.tomSelectSettings(), openOnFocus: false };
|
return {
|
||||||
|
...super.tomSelectSettings(),
|
||||||
|
openOnFocus: false,
|
||||||
|
searchField: ["code", "text"],
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user