- 4단계 상태 플로우: pending → grouped → purchased → received - 한국어 스마트 검색: 초성 매칭(ㅁㅈㄱ→면장갑), 별칭 테이블, 인메모리 캐시 - 모바일 전용 신청 페이지: 바텀시트 UI, FAB, 카드 리스트, 스크롤 페이지네이션 - 인라인 품목 등록: 미등록 품목 검색→등록→신청 단일 트랜잭션 - 관리자 그룹화: 체크박스 다중 선택, 구매 그룹(batch) 생성/일괄 구매/입고 - 입고 처리: 사진+보관위치 등록, 부분 입고 허용, batch 자동 상태 전환 - 알림: notifyHelper에 target_user_ids 추가, 구매진행중/입고완료 시 신청자 ntfy+push Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
36 lines
898 B
JavaScript
36 lines
898 B
JavaScript
// models/itemAliasModel.js
|
|
const { getDb } = require('../dbPool');
|
|
|
|
const ItemAliasModel = {
|
|
async getAll() {
|
|
const db = await getDb();
|
|
const [rows] = await db.query(
|
|
`SELECT ia.*, ci.item_name, ci.spec, ci.maker, ci.category
|
|
FROM item_aliases ia
|
|
JOIN consumable_items ci ON ia.item_id = ci.item_id
|
|
ORDER BY ci.item_name, ia.alias_name`
|
|
);
|
|
return rows;
|
|
},
|
|
|
|
async create(itemId, aliasName) {
|
|
const db = await getDb();
|
|
const [result] = await db.query(
|
|
`INSERT INTO item_aliases (item_id, alias_name) VALUES (?, ?)`,
|
|
[itemId, aliasName.trim()]
|
|
);
|
|
return result.insertId;
|
|
},
|
|
|
|
async delete(aliasId) {
|
|
const db = await getDb();
|
|
const [result] = await db.query(
|
|
`DELETE FROM item_aliases WHERE alias_id = ?`,
|
|
[aliasId]
|
|
);
|
|
return result.affectedRows > 0;
|
|
}
|
|
};
|
|
|
|
module.exports = ItemAliasModel;
|