@movvjs/svelte-schedule-view 0.3.0 → 0.4.1-beta-1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.svelte-kit/__package__/i18n/locales/en.json +7 -0
- package/.svelte-kit/__package__/i18n/locales/ko.json +7 -0
- package/.svelte-kit/__package__/i18n/locales/vi.json +7 -0
- package/.svelte-kit/__package__/i18n/locales/zh-cn.json +7 -0
- package/.svelte-kit/__package__/i18n/locales/zh-tw.json +7 -0
- package/.svelte-kit/__package__/schedule-view/BookingInfo.svelte +21 -2
- package/.svelte-kit/__package__/schedule-view/Calender.svelte +246 -0
- package/.svelte-kit/__package__/schedule-view/Calender.svelte.d.ts +22 -0
- package/.svelte-kit/__package__/schedule-view/Layout.svelte +7 -4
- package/.svelte-kit/__package__/schedule-view/Layout.svelte.d.ts +3 -1
- package/.svelte-kit/__package__/schedule-view/Schedule.svelte +2 -1
- package/.svelte-kit/__package__/schedule-view/Schedule.svelte.d.ts +1 -0
- package/.svelte-kit/__package__/schedule-view/actions/clickOutside.d.ts +3 -0
- package/.svelte-kit/__package__/schedule-view/actions/clickOutside.js +15 -0
- package/.svelte-kit/__package__/schedule-view/assets/scss/indie_booking.scss +411 -0
- package/.svelte-kit/__package__/schedule-view/stores/booking.d.ts +8 -0
- package/.svelte-kit/__package__/schedule-view/stores/booking.js +16 -1
- package/.svelte-kit/ambient.d.ts +0 -4
- package/.svelte-kit/generated/server/internal.js +1 -1
- package/dist/i18n/locales/en.json +7 -0
- package/dist/i18n/locales/ko.json +7 -0
- package/dist/i18n/locales/vi.json +7 -0
- package/dist/i18n/locales/zh-cn.json +7 -0
- package/dist/i18n/locales/zh-tw.json +7 -0
- package/dist/schedule-view/BookingInfo.svelte +21 -2
- package/dist/schedule-view/Calender.svelte +246 -0
- package/dist/schedule-view/Calender.svelte.d.ts +22 -0
- package/dist/schedule-view/Layout.svelte +7 -4
- package/dist/schedule-view/Layout.svelte.d.ts +3 -1
- package/dist/schedule-view/Schedule.svelte +2 -1
- package/dist/schedule-view/Schedule.svelte.d.ts +1 -0
- package/dist/schedule-view/actions/clickOutside.d.ts +3 -0
- package/dist/schedule-view/actions/clickOutside.js +15 -0
- package/dist/schedule-view/assets/scss/indie_booking.scss +411 -0
- package/dist/schedule-view/stores/booking.d.ts +8 -0
- package/dist/schedule-view/stores/booking.js +16 -1
- package/package.json +1 -1
- package/src/additional-svelte-typing.d.ts +10 -0
- package/src/lib/i18n/locales/en.json +7 -0
- package/src/lib/i18n/locales/ko.json +7 -0
- package/src/lib/i18n/locales/vi.json +7 -0
- package/src/lib/i18n/locales/zh-cn.json +7 -0
- package/src/lib/i18n/locales/zh-tw.json +7 -0
- package/src/lib/schedule-view/BookingInfo.svelte +24 -2
- package/src/lib/schedule-view/Calender.svelte +283 -0
- package/src/lib/schedule-view/Layout.svelte +8 -4
- package/src/lib/schedule-view/Schedule.svelte +2 -2
- package/src/lib/schedule-view/actions/clickOutside.ts +17 -0
- package/src/lib/schedule-view/assets/scss/indie_booking.scss +411 -0
- package/src/lib/schedule-view/stores/booking.ts +17 -1
- package/src/routes/development/+page.svelte +2 -2
- package/sync-assets.sh +1 -1
|
@@ -60,6 +60,13 @@
|
|
|
60
60
|
"REQUEST": "STANDBY",
|
|
61
61
|
"RESERV": "CONFIRMED"
|
|
62
62
|
},
|
|
63
|
+
"calender": {
|
|
64
|
+
"complete": "Complete",
|
|
65
|
+
"next": "Next",
|
|
66
|
+
"please-select-month": "Please select a month",
|
|
67
|
+
"please-select-year": "Please select a year",
|
|
68
|
+
"selection-completed": "Selection completed"
|
|
69
|
+
},
|
|
63
70
|
"error": {
|
|
64
71
|
"pleaseEnterGuestName": "Please enter guest name",
|
|
65
72
|
"pleaseEnterTelNumber": "Please enter tel number."
|
|
@@ -47,6 +47,13 @@
|
|
|
47
47
|
"useTime": "이용시간",
|
|
48
48
|
"waypointZone": "경유지 존"
|
|
49
49
|
},
|
|
50
|
+
"calender": {
|
|
51
|
+
"complete": "완료",
|
|
52
|
+
"next": "다음",
|
|
53
|
+
"please-select-month": "월을 선택해주세요.",
|
|
54
|
+
"please-select-year": "년도를 선택해주세요.",
|
|
55
|
+
"selection-completed": "선택 완료"
|
|
56
|
+
},
|
|
50
57
|
"error": {
|
|
51
58
|
"pleaseEnterGuestName": "이름을 입력하세요.",
|
|
52
59
|
"pleaseEnterTelNumber": "전화번호를 입력해주세요."
|
|
@@ -47,6 +47,13 @@
|
|
|
47
47
|
"useTime": "Thời gian sử dụng",
|
|
48
48
|
"waypointZone": "Khu vực điểm dừng"
|
|
49
49
|
},
|
|
50
|
+
"calender": {
|
|
51
|
+
"complete": "Hoàn tất",
|
|
52
|
+
"next": "Tiếp theo",
|
|
53
|
+
"please-select-month": "Vui lòng chọn tháng.",
|
|
54
|
+
"please-select-year": "Vui lòng chọn năm.",
|
|
55
|
+
"selection-completed": "Hoàn tất lựa chọn"
|
|
56
|
+
},
|
|
50
57
|
"error": {
|
|
51
58
|
"pleaseEnterGuestName": "Vui lòng nhập tên khách",
|
|
52
59
|
"pleaseEnterTelNumber": "Vui lòng nhập số điện thoại."
|
|
@@ -47,6 +47,13 @@
|
|
|
47
47
|
"useTime": "使用时间",
|
|
48
48
|
"waypointZone": "停靠点区域"
|
|
49
49
|
},
|
|
50
|
+
"calender": {
|
|
51
|
+
"complete": "完成",
|
|
52
|
+
"next": "下一步",
|
|
53
|
+
"please-select-month": "请选择月份。",
|
|
54
|
+
"please-select-year": "请选择年份。",
|
|
55
|
+
"selection-completed": "选择完成"
|
|
56
|
+
},
|
|
50
57
|
"error": {
|
|
51
58
|
"pleaseEnterGuestName": "请输入客人姓名",
|
|
52
59
|
"pleaseEnterTelNumber": "请输入电话号码。"
|
|
@@ -47,6 +47,13 @@
|
|
|
47
47
|
"useTime": "使用時間",
|
|
48
48
|
"waypointZone": "停靠點區域"
|
|
49
49
|
},
|
|
50
|
+
"calender": {
|
|
51
|
+
"complete": "完成",
|
|
52
|
+
"next": "下一步",
|
|
53
|
+
"please-select-month": "請選擇月份。",
|
|
54
|
+
"please-select-year": "請選擇年份。",
|
|
55
|
+
"selection-completed": "選擇完成"
|
|
56
|
+
},
|
|
50
57
|
"error": {
|
|
51
58
|
"pleaseEnterGuestName": "請輸入客人姓名",
|
|
52
59
|
"pleaseEnterTelNumber": "請輸入電話號碼。"
|
|
@@ -15,9 +15,12 @@ import FlightSearch from "./components/flight-search/FlightSearch.svelte";
|
|
|
15
15
|
import PhoneNumberInput from "./PhoneNumberInput.svelte";
|
|
16
16
|
import FileUploader from "./FileUploader.svelte";
|
|
17
17
|
import CarSearch from "./CarSearch.svelte";
|
|
18
|
+
import Calender from "./Calender.svelte";
|
|
18
19
|
const { stdt, fullName, pax, extraServices, files, plans, isFlightService } = originalBooking;
|
|
19
20
|
const {
|
|
20
21
|
withPreserveAndPreview,
|
|
22
|
+
stdt: copiedStdt,
|
|
23
|
+
ymd,
|
|
21
24
|
hour,
|
|
22
25
|
minute,
|
|
23
26
|
firstName,
|
|
@@ -36,6 +39,7 @@ const {
|
|
|
36
39
|
} = copiedBooking;
|
|
37
40
|
let translation$;
|
|
38
41
|
let flightSearch$;
|
|
42
|
+
let calender$;
|
|
39
43
|
async function copyContents() {
|
|
40
44
|
const texts = [];
|
|
41
45
|
texts.push(`FMS CODE : ${$originalBooking.code}`);
|
|
@@ -145,6 +149,10 @@ function getTerminalName(flight) {
|
|
|
145
149
|
return null;
|
|
146
150
|
}
|
|
147
151
|
}
|
|
152
|
+
function openCalender() {
|
|
153
|
+
calender$.open($stdt).then((date) => $ymd = date).catch(() => {
|
|
154
|
+
});
|
|
155
|
+
}
|
|
148
156
|
</script>
|
|
149
157
|
|
|
150
158
|
<Translation bind:this={translation$} />
|
|
@@ -168,8 +176,19 @@ function getTerminalName(flight) {
|
|
|
168
176
|
<tr>
|
|
169
177
|
<th>{$t('booking.travelDate')}</th>
|
|
170
178
|
<td>
|
|
171
|
-
|
|
172
|
-
|
|
179
|
+
{#if !$isEdit}
|
|
180
|
+
<p class="value-txt">{dayjs($stdt).format('ll (dd)')}</p>
|
|
181
|
+
{:else}
|
|
182
|
+
<div class="indie_po_re">
|
|
183
|
+
<input
|
|
184
|
+
value={dayjs($copiedStdt).format('ll (dd)')}
|
|
185
|
+
type="text"
|
|
186
|
+
class="indie_text_nor xs3 white w100"
|
|
187
|
+
readonly
|
|
188
|
+
on:click={() => openCalender()} />
|
|
189
|
+
<Calender bind:this={calender$} />
|
|
190
|
+
</div>
|
|
191
|
+
{/if}
|
|
173
192
|
</td>
|
|
174
193
|
</tr>
|
|
175
194
|
<tr>
|
|
@@ -0,0 +1,246 @@
|
|
|
1
|
+
<script>import { dayjs } from "../dayjs";
|
|
2
|
+
import { t } from "../i18n";
|
|
3
|
+
import { range } from "lodash-es";
|
|
4
|
+
import { clickOutside } from "./actions/clickOutside";
|
|
5
|
+
export let format = "YYYY-MM-DD HH:mm:ss";
|
|
6
|
+
export let maxYear = dayjs().year();
|
|
7
|
+
export let minYear = 1980;
|
|
8
|
+
export let disabledDate = (date) => false;
|
|
9
|
+
let on = false;
|
|
10
|
+
let target = dayjs().locale("en");
|
|
11
|
+
let resolveFn;
|
|
12
|
+
let rejectFn;
|
|
13
|
+
let time = "am";
|
|
14
|
+
let hour = 0;
|
|
15
|
+
let minute = 0;
|
|
16
|
+
let stdt = null;
|
|
17
|
+
let selectedYear;
|
|
18
|
+
let selectedMonth;
|
|
19
|
+
$:
|
|
20
|
+
calendar = function() {
|
|
21
|
+
{
|
|
22
|
+
const cal = [];
|
|
23
|
+
const startWeek = target.startOf("month").week();
|
|
24
|
+
let endWeek = target.endOf("month").week();
|
|
25
|
+
let done = false;
|
|
26
|
+
if (endWeek === 1) {
|
|
27
|
+
let start = target.startOf("month");
|
|
28
|
+
let weekIndex = -1;
|
|
29
|
+
while (!done) {
|
|
30
|
+
start = start.add(1, "week").startOf("week");
|
|
31
|
+
weekIndex++;
|
|
32
|
+
done = target.month() !== start.month();
|
|
33
|
+
}
|
|
34
|
+
endWeek = startWeek + weekIndex;
|
|
35
|
+
}
|
|
36
|
+
for (let week = startWeek; week <= endWeek; week++) {
|
|
37
|
+
const days = Array(7).fill(0).map((n, i) => {
|
|
38
|
+
let day = target.week(week).startOf("week").clone().add(n + i, "day");
|
|
39
|
+
return day;
|
|
40
|
+
});
|
|
41
|
+
cal.push(days);
|
|
42
|
+
}
|
|
43
|
+
return cal;
|
|
44
|
+
}
|
|
45
|
+
}();
|
|
46
|
+
$:
|
|
47
|
+
hour = function() {
|
|
48
|
+
if (time === "am") {
|
|
49
|
+
if (hour < 12)
|
|
50
|
+
return hour;
|
|
51
|
+
else
|
|
52
|
+
return hour === 12 ? 0 : hour - 12;
|
|
53
|
+
} else {
|
|
54
|
+
if (hour >= 12)
|
|
55
|
+
return hour;
|
|
56
|
+
else
|
|
57
|
+
return hour === 0 ? 12 : hour + 12;
|
|
58
|
+
}
|
|
59
|
+
}();
|
|
60
|
+
export function open(startDate) {
|
|
61
|
+
return new Promise((resolve, reject) => {
|
|
62
|
+
resolveFn = resolve;
|
|
63
|
+
rejectFn = reject;
|
|
64
|
+
stdt = null;
|
|
65
|
+
let start = startDate;
|
|
66
|
+
if (start) {
|
|
67
|
+
target = dayjs(start).locale("en").startOf("month");
|
|
68
|
+
stdt = dayjs(start);
|
|
69
|
+
time = dayjs(start).hour() < 12 ? "am" : "pm";
|
|
70
|
+
hour = dayjs(start).hour();
|
|
71
|
+
minute = dayjs(start).minute();
|
|
72
|
+
}
|
|
73
|
+
on = true;
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
function cancel() {
|
|
77
|
+
close();
|
|
78
|
+
rejectFn();
|
|
79
|
+
}
|
|
80
|
+
function close() {
|
|
81
|
+
on = false;
|
|
82
|
+
}
|
|
83
|
+
function prev() {
|
|
84
|
+
target = target.subtract(1, "month").startOf("month");
|
|
85
|
+
}
|
|
86
|
+
function next() {
|
|
87
|
+
target = target.add(1, "month").startOf("month");
|
|
88
|
+
}
|
|
89
|
+
function select(date) {
|
|
90
|
+
if (disabledDate(date))
|
|
91
|
+
return;
|
|
92
|
+
stdt = date;
|
|
93
|
+
}
|
|
94
|
+
function complete() {
|
|
95
|
+
if (!stdt)
|
|
96
|
+
return;
|
|
97
|
+
resolveFn(stdt.hour(hour).minute(minute).second(0).format(format));
|
|
98
|
+
close();
|
|
99
|
+
}
|
|
100
|
+
</script>
|
|
101
|
+
|
|
102
|
+
<article class="indie_calendar-comp-box" class:on use:clickOutside on:outclick={() => on && cancel()}>
|
|
103
|
+
{#if on}
|
|
104
|
+
<div class="title">
|
|
105
|
+
<p class="days">{target.format('YYYY.MM')}</p>
|
|
106
|
+
|
|
107
|
+
<div class="btns">
|
|
108
|
+
<button type="button" class="btn_cal prev" on:click={() => prev()}>이전 달력</button>
|
|
109
|
+
<!-- 클릭 시 scroll-select-box에 클래스 on 추가 -->
|
|
110
|
+
<button type="button" class="btn_calendar" on:click={() => (selectedYear = target.year())}>년도 선택</button>
|
|
111
|
+
<button type="button" class="btn_cal next" on:click={() => next()}>다음 달력</button>
|
|
112
|
+
</div>
|
|
113
|
+
</div>
|
|
114
|
+
|
|
115
|
+
<div class="calender_box">
|
|
116
|
+
<table class="indie_tbl_in_calendar">
|
|
117
|
+
<thead>
|
|
118
|
+
<tr>
|
|
119
|
+
<th>{dayjs().isoWeekday(7).format('ddd')}</th>
|
|
120
|
+
<th>{dayjs().isoWeekday(1).format('ddd')}</th>
|
|
121
|
+
<th>{dayjs().isoWeekday(2).format('ddd')}</th>
|
|
122
|
+
<th>{dayjs().isoWeekday(3).format('ddd')}</th>
|
|
123
|
+
<th>{dayjs().isoWeekday(4).format('ddd')}</th>
|
|
124
|
+
<th>{dayjs().isoWeekday(5).format('ddd')}</th>
|
|
125
|
+
<th>{dayjs().isoWeekday(6).format('ddd')}</th>
|
|
126
|
+
</tr>
|
|
127
|
+
</thead>
|
|
128
|
+
<tbody>
|
|
129
|
+
{#each calendar as week}
|
|
130
|
+
<tr>
|
|
131
|
+
{#each week as day}
|
|
132
|
+
<td
|
|
133
|
+
class:past={day.isBefore(target, 'month') || day.isAfter(target, 'month') || disabledDate(day)}
|
|
134
|
+
class:today={day.isSame(dayjs(), 'day')}
|
|
135
|
+
class:select={stdt && day.isSame(stdt, 'day')}>
|
|
136
|
+
<a href={null} on:click={() => select(day)}>{day.format('D')}</a>
|
|
137
|
+
</td>
|
|
138
|
+
{/each}
|
|
139
|
+
</tr>
|
|
140
|
+
<!-- content here -->
|
|
141
|
+
{/each}
|
|
142
|
+
</tbody>
|
|
143
|
+
</table>
|
|
144
|
+
</div>
|
|
145
|
+
|
|
146
|
+
<!-- 최종 완료 -->
|
|
147
|
+
<!-- disabled 추가 시 회색으로 변경 -->
|
|
148
|
+
<button type="button" class="indie_btn_nor blue lg btn_sec" disabled={!stdt} on:click|stopPropagation={complete}>
|
|
149
|
+
{$t('calender.selection-completed')}
|
|
150
|
+
</button>
|
|
151
|
+
|
|
152
|
+
<!-- <div class="time_box">
|
|
153
|
+
<p class="sbj">
|
|
154
|
+
The start time of the vehicle <br />
|
|
155
|
+
Please choose.
|
|
156
|
+
</p>
|
|
157
|
+
<p class="indie_select_line_form black">
|
|
158
|
+
<span>
|
|
159
|
+
<select>
|
|
160
|
+
<option>AM</option>
|
|
161
|
+
<option>PM</option>
|
|
162
|
+
</select>
|
|
163
|
+
</span>
|
|
164
|
+
<span>
|
|
165
|
+
<select>
|
|
166
|
+
<option>09</option>
|
|
167
|
+
<option>08</option>
|
|
168
|
+
<option>07</option>
|
|
169
|
+
</select>
|
|
170
|
+
</span>
|
|
171
|
+
<span>
|
|
172
|
+
<select>
|
|
173
|
+
<option>00</option>
|
|
174
|
+
<option>01</option>
|
|
175
|
+
<option>02</option>
|
|
176
|
+
</select>
|
|
177
|
+
</span>
|
|
178
|
+
</p>
|
|
179
|
+
</div> -->
|
|
180
|
+
|
|
181
|
+
<!-- 년도 선택 팝업 - 클래스 on 추가 시 표시 -->
|
|
182
|
+
<div class="scroll-select-box" class:on={!!selectedYear}>
|
|
183
|
+
<div class="title">
|
|
184
|
+
<p>{$t('calender.please-select-year')}</p>
|
|
185
|
+
<button type="button" class="btn_close" on:click={() => (selectedYear = null)}>Close</button>
|
|
186
|
+
</div>
|
|
187
|
+
<div class="select_b">
|
|
188
|
+
<ul class="list">
|
|
189
|
+
<!-- 클릭 시 li에 - 클래스 on 추가 -->
|
|
190
|
+
{#each range(maxYear, minYear - 1, -1) as year}
|
|
191
|
+
<li class:on={selectedYear === year}><a href={null} on:click={() => (selectedYear = year)}>{year}</a></li>
|
|
192
|
+
{/each}
|
|
193
|
+
</ul>
|
|
194
|
+
</div>
|
|
195
|
+
<div class="btns">
|
|
196
|
+
<!--
|
|
197
|
+
년도 클릭 전 disabled 추가 후 - Close로 변경
|
|
198
|
+
년도 클릭 시 disabled 제거 후 - Next로 변경
|
|
199
|
+
-->
|
|
200
|
+
<button
|
|
201
|
+
type="button"
|
|
202
|
+
class="indie_btn_nor blue lg btn_sec"
|
|
203
|
+
on:click={() => {
|
|
204
|
+
target = target.set('year', selectedYear)
|
|
205
|
+
selectedYear = null
|
|
206
|
+
selectedMonth = target.month()
|
|
207
|
+
}}>{$t('calender.next')}</button>
|
|
208
|
+
</div>
|
|
209
|
+
</div>
|
|
210
|
+
|
|
211
|
+
<!-- 달 선택 팝업 (위에 년도 선택 후) - 클래스 on 추가 시 표시 -->
|
|
212
|
+
<div class="scroll-select-box" class:on={!!selectedMonth}>
|
|
213
|
+
<div class="title">
|
|
214
|
+
<p>{$t('calender.please-select-month')}</p>
|
|
215
|
+
<button type="button" class="btn_close" on:click={() => (selectedMonth = null)}>Close</button>
|
|
216
|
+
</div>
|
|
217
|
+
<div class="select_b">
|
|
218
|
+
<ul class="list">
|
|
219
|
+
<!-- 클릭 시 li에 - 클래스 on 추가 -->
|
|
220
|
+
{#each range(1, 13, 1) as month}
|
|
221
|
+
<li class:on={selectedMonth === month}>
|
|
222
|
+
<a
|
|
223
|
+
href={null}
|
|
224
|
+
on:click={() => {
|
|
225
|
+
selectedMonth = month
|
|
226
|
+
}}>{month}</a>
|
|
227
|
+
</li>
|
|
228
|
+
{/each}
|
|
229
|
+
</ul>
|
|
230
|
+
</div>
|
|
231
|
+
<div class="btns">
|
|
232
|
+
<!--
|
|
233
|
+
달 클릭 전 disabled 추가 후 - Select a year로 변경
|
|
234
|
+
달 클릭 시 disabled 제거 후 - Complete로 변경
|
|
235
|
+
-->
|
|
236
|
+
<button
|
|
237
|
+
type="button"
|
|
238
|
+
class="indie_btn_nor blue lg btn_sec"
|
|
239
|
+
on:click={() => {
|
|
240
|
+
target = target.set('month', selectedMonth - 1) // ex) 3 = 4월
|
|
241
|
+
selectedMonth = null
|
|
242
|
+
}}>{$t('calender.complete')}</button>
|
|
243
|
+
</div>
|
|
244
|
+
</div>
|
|
245
|
+
{/if}
|
|
246
|
+
</article>
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { SvelteComponent } from "svelte";
|
|
2
|
+
import type { Dayjs } from 'dayjs';
|
|
3
|
+
declare const __propDef: {
|
|
4
|
+
props: {
|
|
5
|
+
format?: string;
|
|
6
|
+
maxYear?: number;
|
|
7
|
+
minYear?: number;
|
|
8
|
+
disabledDate?: (date: Dayjs) => boolean;
|
|
9
|
+
open?: (startDate: string) => Promise<string>;
|
|
10
|
+
};
|
|
11
|
+
events: {
|
|
12
|
+
[evt: string]: CustomEvent<any>;
|
|
13
|
+
};
|
|
14
|
+
slots: {};
|
|
15
|
+
};
|
|
16
|
+
export type CalenderProps = typeof __propDef.props;
|
|
17
|
+
export type CalenderEvents = typeof __propDef.events;
|
|
18
|
+
export type CalenderSlots = typeof __propDef.slots;
|
|
19
|
+
export default class Calender extends SvelteComponent<CalenderProps, CalenderEvents, CalenderSlots> {
|
|
20
|
+
get open(): (startDate: string) => Promise<string>;
|
|
21
|
+
}
|
|
22
|
+
export {};
|
|
@@ -6,10 +6,13 @@ import { env } from "../store/env";
|
|
|
6
6
|
import { Alert, Confirm } from "./components/notifications";
|
|
7
7
|
import Loader from "./components/loader/Loader.svelte";
|
|
8
8
|
import { onMount } from "svelte";
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
9
|
+
export let initI18n;
|
|
10
|
+
if (initI18n) {
|
|
11
|
+
init({
|
|
12
|
+
fallbackLocale: "en",
|
|
13
|
+
initialLocale: "en"
|
|
14
|
+
});
|
|
15
|
+
}
|
|
13
16
|
env.subscribe(($env) => {
|
|
14
17
|
locale.set($env.locale);
|
|
15
18
|
dayjs.locale($env.locale);
|
|
@@ -30,6 +30,7 @@ const {
|
|
|
30
30
|
fullName,
|
|
31
31
|
selectedPrice
|
|
32
32
|
} = copiedBooking;
|
|
33
|
+
export let initI18n = true;
|
|
33
34
|
let on = false;
|
|
34
35
|
let resolver;
|
|
35
36
|
$:
|
|
@@ -160,7 +161,7 @@ async function save() {
|
|
|
160
161
|
</script>
|
|
161
162
|
|
|
162
163
|
<Toaster />
|
|
163
|
-
<Layout>
|
|
164
|
+
<Layout {initI18n}>
|
|
164
165
|
<section class="indie_pop_wrap scroll" class:on>
|
|
165
166
|
{#if on}
|
|
166
167
|
<div class="pop_base full_2 indie_passengers_info_pop">
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
// 바깥 영역 클릭시 이벤트
|
|
2
|
+
// TODO: 다국어 두개 이상일 때 문제 발생하는 부분 있음. 수정 필요
|
|
3
|
+
export function clickOutside(node) {
|
|
4
|
+
const handleClick = event => {
|
|
5
|
+
if (!node.contains(event.target)) {
|
|
6
|
+
node.dispatchEvent(new CustomEvent('outclick'));
|
|
7
|
+
}
|
|
8
|
+
};
|
|
9
|
+
document.addEventListener('click', handleClick, true);
|
|
10
|
+
return {
|
|
11
|
+
destroy() {
|
|
12
|
+
document.removeEventListener('click', handleClick, true);
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
}
|