implementd search in stock items
Signed-off-by: Stephan Richter <s.richter@srsoftware.de>
This commit is contained in:
@@ -105,7 +105,7 @@
|
||||
}
|
||||
}
|
||||
|
||||
async function handleStock(resp){
|
||||
async function handleStock(resp){
|
||||
if (resp.ok){
|
||||
const res = await resp.json();
|
||||
stock = Object.keys(res).length ? res : null;
|
||||
@@ -219,6 +219,23 @@
|
||||
</ul>
|
||||
</fieldset>
|
||||
{/if}
|
||||
{#if stock}
|
||||
<fieldset>
|
||||
<legend>
|
||||
{t('stock')}
|
||||
</legend>
|
||||
<ul>
|
||||
{#each Object.values(stock) as item}
|
||||
<li>
|
||||
<a href="/stock/{item.owner.type}/{item.owner.id}/item/{item.owner_number}" {onclick} >
|
||||
{item.name} [{t('code')}: <span class="code">{item.code}</span>]
|
||||
</a>
|
||||
{@html item.description.rendered}
|
||||
</li>
|
||||
{/each}
|
||||
</ul>
|
||||
</fieldset>
|
||||
{/if}
|
||||
{#if notes}
|
||||
<fieldset>
|
||||
<legend>
|
||||
|
||||
@@ -191,19 +191,21 @@ public class SqliteDb extends BaseDb implements StockDb {
|
||||
}
|
||||
|
||||
@Override
|
||||
public Map<Long, Item> find(long userId, Collection<String> keys, boolean fulltext) {
|
||||
public Map<Long, Item> find(Collection<Owner> owners, Collection<String> keys, boolean fulltext) {
|
||||
try {
|
||||
var items = new HashMap<Long,Item>();
|
||||
var query = select(ALL).from(TABLE_ITEMS).where(USER_ID, equal(userId));
|
||||
var ownerCodes = owners.stream().map(Owner::dbCode).toArray();
|
||||
var query = select(ALL).from(TABLE_ITEMS).where(OWNER, in(ownerCodes));
|
||||
if (fulltext) {
|
||||
// TODO: implement full-text search
|
||||
query.leftJoin(ID,TABLE_ITEM_PROPERTIES,ITEM_ID);
|
||||
for (var key : keys) query.where(format("CONCAT({0},\" \",{1},\" \",{2})",NAME,DESCRIPTION,VALUE),like("%"+key+"%"));
|
||||
} else {
|
||||
for (var key : keys) query.where(NAME,like("%"+key+"%"));
|
||||
}
|
||||
var rs = query.exec(db);
|
||||
while (rs.next()){
|
||||
var project = Item.of(rs);
|
||||
items.put(project.id(),project);
|
||||
var item = Item.of(rs);
|
||||
items.put(item.id(),item);
|
||||
}
|
||||
rs.close();
|
||||
return items;
|
||||
|
||||
@@ -5,13 +5,13 @@ import de.srsoftware.umbrella.core.api.Owner;
|
||||
import de.srsoftware.umbrella.core.model.*;
|
||||
import de.srsoftware.umbrella.core.model.Location;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
|
||||
public interface StockDb {
|
||||
Property addNewProperty(long itemId, String name, Object value, String unit);
|
||||
Location delete(DbLocation location);
|
||||
Map<Long, Item> find(long userId, Collection<String> keys, boolean fulltext);
|
||||
Map<Long, Item> find(Collection<Owner> owners, Collection<String> keys, boolean fulltext);
|
||||
Collection<DbLocation> listChildLocations(long parentId);
|
||||
Collection<DbLocation> listCompanyLocations(Company company);
|
||||
Collection<Item> listItemsAt(Location location);
|
||||
|
||||
@@ -397,7 +397,9 @@ public class StockModule extends BaseHandler implements StockService {
|
||||
if (!(json.has(KEY) && json.get(KEY) instanceof String key)) throw missingFieldException(KEY);
|
||||
var keys = Arrays.asList(key.split(" "));
|
||||
var fulltext = json.has(FULLTEXT) && json.get(FULLTEXT) instanceof Boolean val && val;
|
||||
var items = stockDb.find(user.id(),keys,fulltext);
|
||||
Set<Owner> owners = new HashSet<>(companyService().listCompaniesOf(user).values());
|
||||
owners.add(user);
|
||||
var items = stockDb.find(owners,keys,fulltext);
|
||||
return sendContent(ex,mapValues(items));
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user