mirror of
https://github.com/ae-utbm/sith.git
synced 2025-12-21 07:13:21 +00:00
94 lines
3.1 KiB
TypeScript
94 lines
3.1 KiB
TypeScript
import { AjaxSelect } from "#core:core/components/ajax-select-base";
|
|
import { registerComponent } from "#core:utils/web-components";
|
|
import type { TomOption } from "tom-select/dist/types/types";
|
|
import type { escape_html } from "tom-select/dist/types/utils";
|
|
import {
|
|
type CounterSchema,
|
|
type ProductTypeSchema,
|
|
type SimpleProductSchema,
|
|
counterSearchCounter,
|
|
productSearchProducts,
|
|
producttypeFetchAll,
|
|
} from "#openapi";
|
|
|
|
@registerComponent("product-ajax-select")
|
|
export class ProductAjaxSelect extends AjaxSelect {
|
|
protected valueField = "id";
|
|
protected labelField = "name";
|
|
protected searchField = ["code", "name"];
|
|
|
|
protected async search(query: string): Promise<TomOption[]> {
|
|
const resp = await productSearchProducts({ query: { search: query } });
|
|
if (resp.data) {
|
|
return resp.data.results;
|
|
}
|
|
return [];
|
|
}
|
|
|
|
protected renderOption(item: SimpleProductSchema, sanitize: typeof escape_html) {
|
|
return `<div class="select-item">
|
|
<span class="select-item-text">${sanitize(item.code)} - ${sanitize(item.name)}</span>
|
|
</div>`;
|
|
}
|
|
|
|
protected renderItem(item: SimpleProductSchema, sanitize: typeof escape_html) {
|
|
return `<span>${sanitize(item.code)} - ${sanitize(item.name)}</span>`;
|
|
}
|
|
}
|
|
|
|
@registerComponent("product-type-ajax-select")
|
|
export class ProductTypeAjaxSelect extends AjaxSelect {
|
|
protected valueField = "id";
|
|
protected labelField = "name";
|
|
protected searchField = ["name"];
|
|
private productTypes = null as ProductTypeSchema[];
|
|
|
|
protected async search(query: string): Promise<TomOption[]> {
|
|
// The production database has a grand total of 26 product types
|
|
// and the filter logic is really simple.
|
|
// Thus, it's appropriate to fetch all product types during first use,
|
|
// then to reuse the result again and again.
|
|
if (this.productTypes === null) {
|
|
this.productTypes = (await producttypeFetchAll()).data || null;
|
|
}
|
|
return this.productTypes.filter((t) =>
|
|
t.name.toLowerCase().includes(query.toLowerCase()),
|
|
);
|
|
}
|
|
|
|
protected renderOption(item: ProductTypeSchema, sanitize: typeof escape_html) {
|
|
return `<div class="select-item">
|
|
<span class="select-item-text">${sanitize(item.name)}</span>
|
|
</div>`;
|
|
}
|
|
|
|
protected renderItem(item: ProductTypeSchema, sanitize: typeof escape_html) {
|
|
return `<span>${sanitize(item.name)}</span>`;
|
|
}
|
|
}
|
|
|
|
@registerComponent("counter-ajax-select")
|
|
export class CounterAjaxSelect extends AjaxSelect {
|
|
protected valueField = "id";
|
|
protected labelField = "name";
|
|
protected searchField = ["code", "name"];
|
|
|
|
protected async search(query: string): Promise<TomOption[]> {
|
|
const resp = await counterSearchCounter({ query: { search: query } });
|
|
if (resp.data) {
|
|
return resp.data.results;
|
|
}
|
|
return [];
|
|
}
|
|
|
|
protected renderOption(item: CounterSchema, sanitize: typeof escape_html) {
|
|
return `<div class="select-item">
|
|
<span class="select-item-text">${sanitize(item.name)}</span>
|
|
</div>`;
|
|
}
|
|
|
|
protected renderItem(item: CounterSchema, sanitize: typeof escape_html) {
|
|
return `<span>${sanitize(item.name)}</span>`;
|
|
}
|
|
}
|