- 검색바: 아이콘 내장, 모드 select 제거 (hybrid 고정), 엔터 검색 - 필터 그룹화: [음식 장르·가격] [지역 나라·시·구] + X 해제 버튼 - 채널 필터: 드롭다운 → 유튜브 아이콘 토글 카드, 드래그 스크롤 - 채널 정렬: sort_order 컬럼 추가, 백오피스 순서 편집 - 채널+필터 동시 적용: API 호출 대신 클라이언트 필터링 - 내위치 ON 시 다른 필터 초기화, 역방향도 동일 - 전체보기 버튼: 모든 필터 일괄 해제 - 네이버맵: 한국 식당만, 식당명만 검색 - 구글맵: 식당명+주소/지역 검색 - 로그인 영역 데스크톱 Row 1 우측 배치 - scrollbar-hide CSS 추가 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
53 lines
2.1 KiB
XML
53 lines
2.1 KiB
XML
<?xml version="1.0" encoding="UTF-8" ?>
|
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
|
<mapper namespace="com.tasteby.mapper.ChannelMapper">
|
|
|
|
<resultMap id="channelResultMap" type="com.tasteby.domain.Channel">
|
|
<id property="id" column="id"/>
|
|
<result property="channelId" column="channel_id"/>
|
|
<result property="channelName" column="channel_name"/>
|
|
<result property="titleFilter" column="title_filter"/>
|
|
<result property="description" column="description"/>
|
|
<result property="tags" column="tags"/>
|
|
<result property="sortOrder" column="sort_order"/>
|
|
<result property="videoCount" column="video_count"/>
|
|
<result property="lastVideoAt" column="last_video_at"/>
|
|
</resultMap>
|
|
|
|
<select id="findAllActive" resultMap="channelResultMap">
|
|
SELECT c.id, c.channel_id, c.channel_name, c.title_filter, c.description, c.tags, c.sort_order,
|
|
(SELECT COUNT(*) FROM videos v WHERE v.channel_id = c.id) AS video_count,
|
|
(SELECT MAX(v.published_at) FROM videos v WHERE v.channel_id = c.id) AS last_video_at
|
|
FROM channels c
|
|
WHERE c.is_active = 1
|
|
ORDER BY c.sort_order, c.channel_name
|
|
</select>
|
|
|
|
<insert id="insert">
|
|
INSERT INTO channels (id, channel_id, channel_name, title_filter)
|
|
VALUES (#{id}, #{channelId}, #{channelName}, #{titleFilter})
|
|
</insert>
|
|
|
|
<update id="deactivateByChannelId">
|
|
UPDATE channels SET is_active = 0
|
|
WHERE channel_id = #{channelId} AND is_active = 1
|
|
</update>
|
|
|
|
<update id="deactivateById">
|
|
UPDATE channels SET is_active = 0
|
|
WHERE id = #{id} AND is_active = 1
|
|
</update>
|
|
|
|
<update id="updateChannel">
|
|
UPDATE channels SET description = #{description}, tags = #{tags}, sort_order = #{sortOrder}
|
|
WHERE id = #{id}
|
|
</update>
|
|
|
|
<select id="findByChannelId" resultMap="channelResultMap">
|
|
SELECT id, channel_id, channel_name, title_filter
|
|
FROM channels
|
|
WHERE channel_id = #{channelId} AND is_active = 1
|
|
</select>
|
|
|
|
</mapper>
|