ps-toolkit-ui 1.21.42 → 1.21.51
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/bundles/ps-toolkit-ui.umd.js +10321 -0
- package/bundles/ps-toolkit-ui.umd.js.map +1 -0
- package/bundles/ps-toolkit-ui.umd.min.js +2 -0
- package/bundles/ps-toolkit-ui.umd.min.js.map +1 -0
- package/esm2015/lib/classes/addModal.class.js +36 -0
- package/esm2015/lib/classes/chart.class.js +165 -0
- package/esm2015/lib/classes/currentDataClass.js +17 -0
- package/esm2015/lib/classes/enum.class.js +253 -0
- package/esm2015/lib/classes/excel.class.js +56 -0
- package/esm2015/lib/classes/form.class.js +667 -0
- package/esm2015/lib/classes/header.class.js +16 -0
- package/esm2015/lib/classes/helper.class.js +650 -0
- package/esm2015/lib/classes/lang.class.js +35 -0
- package/esm2015/lib/classes/login.class.js +29 -0
- package/esm2015/lib/classes/modal.class.js +49 -0
- package/esm2015/lib/classes/permission.class.js +63 -0
- package/esm2015/lib/classes/request.class.js +155 -0
- package/esm2015/lib/classes/safehtml.class.js +17 -0
- package/esm2015/lib/classes/safestyle.class.js +17 -0
- package/esm2015/lib/classes/sidebar.class.js +16 -0
- package/esm2015/lib/classes/steps.class.js +45 -0
- package/esm2015/lib/classes/string.class.js +251 -0
- package/esm2015/lib/classes/table.class.js +593 -0
- package/esm2015/lib/components/accordion/accordion.component.js +45 -0
- package/esm2015/lib/components/alert/alert.component.js +39 -0
- package/esm2015/lib/components/base.component.js +54 -0
- package/esm2015/lib/components/calendar/calendar.component.js +98 -0
- package/esm2015/lib/components/chart/chart.component.js +17 -0
- package/esm2015/lib/components/clock/clock.component.js +33 -0
- package/esm2015/lib/components/confirm/confirm.component.js +50 -0
- package/esm2015/lib/components/error/error.component.js +26 -0
- package/esm2015/lib/components/footer/footer.component.js +23 -0
- package/esm2015/lib/components/form/bank-card/form.bank-card.component.js +200 -0
- package/esm2015/lib/components/form/button/form.button.component.js +68 -0
- package/esm2015/lib/components/form/checkbox/form.checkbox.component.js +67 -0
- package/esm2015/lib/components/form/ckeditor/form.ckeditor.component.js +90 -0
- package/esm2015/lib/components/form/date/form.date.component.js +314 -0
- package/esm2015/lib/components/form/datetime/form.datetime.component.js +106 -0
- package/esm2015/lib/components/form/file/form.file.component.js +124 -0
- package/esm2015/lib/components/form/finger/form.finger.component.js +140 -0
- package/esm2015/lib/components/form/hidden/form.hidden.component.js +31 -0
- package/esm2015/lib/components/form/icon/form.icon.component.js +84 -0
- package/esm2015/lib/components/form/index/form.component.js +51 -0
- package/esm2015/lib/components/form/label/form.label.component.js +32 -0
- package/esm2015/lib/components/form/plaque/form.plaque.component.js +258 -0
- package/esm2015/lib/components/form/plaque/select/form.plaque.select.component.js +468 -0
- package/esm2015/lib/components/form/radio/form.radio.component.js +82 -0
- package/esm2015/lib/components/form/select/form.select.component.js +452 -0
- package/esm2015/lib/components/form/select/item/form.select.item.component.js +27 -0
- package/esm2015/lib/components/form/slide/form.slide.component.js +84 -0
- package/esm2015/lib/components/form/star/form.star.component.js +66 -0
- package/esm2015/lib/components/form/table/form.table.component.js +96 -0
- package/esm2015/lib/components/form/tag/form.tag.component.js +100 -0
- package/esm2015/lib/components/form/textarea/form.textarea.component.js +83 -0
- package/esm2015/lib/components/form/textbox/form.textbox.component.js +227 -0
- package/esm2015/lib/components/form/time/form.time.component.js +149 -0
- package/esm2015/lib/components/form/toggle/form.toggle.component.js +72 -0
- package/esm2015/lib/components/form/tree/form.tree.component.js +157 -0
- package/esm2015/lib/components/form/tree/item/form.tree.item.component.js +50 -0
- package/esm2015/lib/components/form/uploader/form.uploader.component.js +159 -0
- package/esm2015/lib/components/form/vehicle/form.vehicle.component.js +104 -0
- package/esm2015/lib/components/form/vehicle/search/form.vehicle.search.component.js +237 -0
- package/esm2015/lib/components/header/header.component.js +28 -0
- package/esm2015/lib/components/header/sub/sub.header.component.js +14 -0
- package/esm2015/lib/components/layout/layout.component.js +18 -0
- package/esm2015/lib/components/loading/loading.component.js +22 -0
- package/esm2015/lib/components/login/login.component.js +159 -0
- package/esm2015/lib/components/modal/modal.component.js +25 -0
- package/esm2015/lib/components/notfound/notfound.component.js +29 -0
- package/esm2015/lib/components/notification/notification.component.js +14 -0
- package/esm2015/lib/components/sidebar/item/sidebar.item.component.js +55 -0
- package/esm2015/lib/components/sidebar/sidebar.component.js +98 -0
- package/esm2015/lib/components/steps/steps.component.js +88 -0
- package/esm2015/lib/components/table/loading/table.loading.component.js +17 -0
- package/esm2015/lib/components/table/pagination/table.pagination.component.js +84 -0
- package/esm2015/lib/components/table/row/table.row.component.js +450 -0
- package/esm2015/lib/components/table/table.component.js +240 -0
- package/esm2015/lib/components/tooltip/tooltip.component.js +19 -0
- package/esm2015/lib/ps-toolkit-ui.module.js +105 -0
- package/esm2015/lib/services/config.service.js +14 -0
- package/esm2015/lib/services/sidebar.service.js +21 -0
- package/esm2015/ps-toolkit-ui.js +21 -0
- package/esm2015/public-api.js +64 -0
- package/fesm2015/ps-toolkit-ui.js +8926 -0
- package/fesm2015/ps-toolkit-ui.js.map +1 -0
- package/lib/classes/addModal.class.d.ts +14 -0
- package/lib/classes/chart.class.d.ts +15 -0
- package/lib/classes/currentDataClass.d.ts +10 -0
- package/lib/classes/enum.class.d.ts +221 -0
- package/lib/classes/excel.class.d.ts +8 -0
- package/lib/classes/form.class.d.ts +193 -0
- package/lib/classes/header.class.d.ts +8 -0
- package/lib/classes/helper.class.d.ts +50 -0
- package/lib/classes/lang.class.d.ts +5 -0
- package/lib/classes/login.class.d.ts +21 -0
- package/lib/classes/modal.class.d.ts +19 -0
- package/lib/classes/permission.class.d.ts +35 -0
- package/lib/classes/request.class.d.ts +10 -0
- package/lib/classes/safehtml.class.d.ts +7 -0
- package/lib/classes/safestyle.class.d.ts +7 -0
- package/lib/classes/sidebar.class.d.ts +14 -0
- package/lib/classes/steps.class.d.ts +31 -0
- package/lib/classes/string.class.d.ts +249 -0
- package/lib/classes/table.class.d.ts +88 -0
- package/lib/components/accordion/accordion.component.d.ts +7 -0
- package/lib/components/alert/alert.component.d.ts +10 -0
- package/lib/components/base.component.d.ts +17 -0
- package/lib/components/calendar/calendar.component.d.ts +26 -0
- package/lib/components/chart/chart.component.d.ts +5 -0
- package/lib/components/clock/clock.component.d.ts +11 -0
- package/lib/components/confirm/confirm.component.d.ts +14 -0
- package/lib/components/error/error.component.d.ts +7 -0
- package/lib/components/footer/footer.component.d.ts +6 -0
- package/lib/components/form/bank-card/form.bank-card.component.d.ts +28 -0
- package/lib/components/form/button/form.button.component.d.ts +15 -0
- package/lib/components/form/checkbox/form.checkbox.component.d.ts +14 -0
- package/lib/components/form/ckeditor/form.ckeditor.component.d.ts +14 -0
- package/lib/components/form/date/form.date.component.d.ts +45 -0
- package/lib/components/form/datetime/form.datetime.component.d.ts +13 -0
- package/lib/components/form/file/form.file.component.d.ts +18 -0
- package/lib/components/form/finger/form.finger.component.d.ts +15 -0
- package/lib/components/form/hidden/form.hidden.component.d.ts +7 -0
- package/lib/components/form/icon/form.icon.component.d.ts +16 -0
- package/lib/components/form/index/form.component.d.ts +10 -0
- package/lib/components/form/label/form.label.component.d.ts +8 -0
- package/lib/components/form/plaque/form.plaque.component.d.ts +21 -0
- package/lib/components/form/plaque/select/form.plaque.select.component.d.ts +38 -0
- package/lib/components/form/radio/form.radio.component.d.ts +13 -0
- package/lib/components/form/select/form.select.component.d.ts +45 -0
- package/lib/components/form/select/item/form.select.item.component.d.ts +12 -0
- package/lib/components/form/slide/form.slide.component.d.ts +13 -0
- package/lib/components/form/star/form.star.component.d.ts +13 -0
- package/lib/components/form/table/form.table.component.d.ts +9 -0
- package/lib/components/form/tag/form.tag.component.d.ts +16 -0
- package/lib/components/form/textarea/form.textarea.component.d.ts +13 -0
- package/lib/components/form/textbox/form.textbox.component.d.ts +20 -0
- package/lib/components/form/time/form.time.component.d.ts +25 -0
- package/lib/components/form/toggle/form.toggle.component.d.ts +13 -0
- package/lib/components/form/tree/form.tree.component.d.ts +21 -0
- package/lib/components/form/tree/item/form.tree.item.component.d.ts +19 -0
- package/lib/components/form/uploader/form.uploader.component.d.ts +21 -0
- package/lib/components/form/vehicle/form.vehicle.component.d.ts +18 -0
- package/lib/components/form/vehicle/search/form.vehicle.search.component.d.ts +22 -0
- package/lib/components/header/header.component.d.ts +10 -0
- package/lib/components/header/sub/sub.header.component.d.ts +3 -0
- package/lib/components/layout/layout.component.d.ts +7 -0
- package/lib/components/loading/loading.component.d.ts +5 -0
- package/lib/components/login/login.component.d.ts +15 -0
- package/lib/components/modal/modal.component.d.ts +9 -0
- package/lib/components/notfound/notfound.component.d.ts +8 -0
- package/lib/components/notification/notification.component.d.ts +3 -0
- package/lib/components/sidebar/item/sidebar.item.component.d.ts +14 -0
- package/lib/components/sidebar/sidebar.component.d.ts +22 -0
- package/lib/components/steps/steps.component.d.ts +16 -0
- package/lib/components/table/loading/table.loading.component.d.ts +5 -0
- package/lib/components/table/pagination/table.pagination.component.d.ts +15 -0
- package/lib/components/table/row/table.row.component.d.ts +44 -0
- package/lib/components/table/table.component.d.ts +43 -0
- package/lib/components/tooltip/tooltip.component.d.ts +5 -0
- package/lib/ps-toolkit-ui.module.d.ts +4 -0
- package/lib/services/config.service.d.ts +6 -0
- package/lib/services/sidebar.service.d.ts +9 -0
- package/package.json +12 -16
- package/ps-toolkit-ui.d.ts +20 -0
- package/ps-toolkit-ui.metadata.json +1 -0
- package/public-api.d.ts +60 -0
- package/fesm2022/ps-toolkit-ui.mjs +0 -9472
- package/fesm2022/ps-toolkit-ui.mjs.map +0 -1
- package/types/ps-toolkit-ui.d.ts +0 -1671
|
@@ -0,0 +1,314 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import * as moment from 'jalali-moment';
|
|
3
|
+
import * as $ from 'jquery';
|
|
4
|
+
import { DayClass } from '../../../classes/form.class';
|
|
5
|
+
import { InputError, InputType } from '../../../classes/enum.class';
|
|
6
|
+
export class FormDateComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.changeIndex = new EventEmitter();
|
|
9
|
+
this.previousDays = [];
|
|
10
|
+
this.nextDays = [];
|
|
11
|
+
this.days = [];
|
|
12
|
+
this.cSearch = '';
|
|
13
|
+
this.state = 'day';
|
|
14
|
+
this.months = ['فروردین', 'اردیبهشت', 'خرداد', 'تیر', 'مرداد', 'شهریور', 'مهر', 'آبان', 'آذر', 'دی', 'بهمن', 'اسفند'];
|
|
15
|
+
this.active = moment();
|
|
16
|
+
}
|
|
17
|
+
get type() { return InputType; }
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
const today = moment().locale('fa');
|
|
20
|
+
this.todayDay = parseInt(today.format('jDD'), 10);
|
|
21
|
+
this.todayMonth = parseInt(today.format('jMM'), 10);
|
|
22
|
+
this.todayYear = parseInt(today.format('jYYYY'), 10);
|
|
23
|
+
this.state = this.inp.type === InputType.Year ? 'year' : this.inp.type === InputType.Month ? 'month' : 'day';
|
|
24
|
+
this.setInpValue(this.inp.value);
|
|
25
|
+
this.inp.setValue = (v) => {
|
|
26
|
+
this.setInpValue(v);
|
|
27
|
+
};
|
|
28
|
+
this.inp.isValid = () => {
|
|
29
|
+
this.inp.error = null;
|
|
30
|
+
if (this.inp.required && !this.inp.value) {
|
|
31
|
+
this.inp.error = InputError.Required;
|
|
32
|
+
return false;
|
|
33
|
+
}
|
|
34
|
+
if (!this.inp.required && !this.inp.value) {
|
|
35
|
+
return true;
|
|
36
|
+
}
|
|
37
|
+
if (!moment(this.inp.value, 'jYYYY/jMM/jDD').isValid()) {
|
|
38
|
+
this.inp.error = InputError.Invalid;
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
return true;
|
|
42
|
+
};
|
|
43
|
+
this.inp.clear = () => {
|
|
44
|
+
this.inp.error = null;
|
|
45
|
+
if (this.inp.default) {
|
|
46
|
+
this.inp.setValue(this.inp.default, false);
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
this.inp.value = null;
|
|
50
|
+
this.inp.search = null;
|
|
51
|
+
}
|
|
52
|
+
if (this.inp.onChange) {
|
|
53
|
+
this.inp.onChange(this.inp);
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
this.inp.data = () => {
|
|
57
|
+
return this.inp.value ? moment(this.inp.value, 'jYYYY/jMM/jDD').locale('en').format('YYYY/MM/DD') : null;
|
|
58
|
+
};
|
|
59
|
+
this.inp.focus = () => {
|
|
60
|
+
this.openCalendar();
|
|
61
|
+
};
|
|
62
|
+
this.inp.focusOut = () => {
|
|
63
|
+
$(this.inputBase.nativeElement).blur();
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
setInpValue(v) {
|
|
67
|
+
if (v === null) {
|
|
68
|
+
this.inp.clear();
|
|
69
|
+
this.active = moment().locale('fa');
|
|
70
|
+
this.setDate();
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
else if (typeof v === 'string' && v.length === 10) {
|
|
74
|
+
this.active = moment(v, 'YYYY/MM/DD').locale('fa');
|
|
75
|
+
}
|
|
76
|
+
else if (typeof v === 'string') {
|
|
77
|
+
const d = parseInt(v.substring(6, v.length - 2), 10);
|
|
78
|
+
this.active = moment(d).locale('fa');
|
|
79
|
+
}
|
|
80
|
+
else if (typeof v === 'number') {
|
|
81
|
+
this.active = this.inp.type === InputType.Month ? moment(moment(v).locale('fa').format('jYYYY/jMM/jDD'), 'jYYYY/jMM/01').locale('fa') : moment(v).locale('fa');
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
this.active = v;
|
|
85
|
+
}
|
|
86
|
+
this.inp.value = this.active.format('jYYYY/jMM/jDD');
|
|
87
|
+
this.inp.search = this.cSearch = this.active.format(this.inp.type === InputType.Year ? 'jYYYY' : this.inp.type === InputType.Month ? 'jMMMM jYYYY' : 'jYYYY/jMM/jDD');
|
|
88
|
+
this.state = this.inp.type === InputType.Year ? 'year' : this.inp.type === InputType.Month ? 'month' : 'day';
|
|
89
|
+
this.setDate();
|
|
90
|
+
}
|
|
91
|
+
setDate() {
|
|
92
|
+
const n = this.active.clone();
|
|
93
|
+
const countDayInMonth = n.locale('fa').daysInMonth();
|
|
94
|
+
const startWeek = parseInt(n.startOf('month').format('d'), 10);
|
|
95
|
+
const previousMonth = n.subtract(1, 'month');
|
|
96
|
+
const countDayInPreviousMonth = previousMonth.daysInMonth();
|
|
97
|
+
const nextMonth = n.add(2, 'month');
|
|
98
|
+
const previousDays = [];
|
|
99
|
+
const nextDays = [];
|
|
100
|
+
const days = [];
|
|
101
|
+
if (startWeek !== 6) {
|
|
102
|
+
for (let i = countDayInPreviousMonth - startWeek; i <= countDayInPreviousMonth; i++) {
|
|
103
|
+
previousDays.push(new DayClass(i, this.isToday(previousMonth, i), false, false));
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
for (let i = 1; i <= countDayInMonth; i++) {
|
|
107
|
+
let isActive = true;
|
|
108
|
+
if (this.inp.allowed != null && this.inp.allowed.length > 0) {
|
|
109
|
+
isActive = this.isActive(this.active, i);
|
|
110
|
+
}
|
|
111
|
+
days.push(new DayClass(i, this.isToday(this.active, i), this.isSelected(this.active, i), isActive));
|
|
112
|
+
}
|
|
113
|
+
const end = (days.length + previousDays.length) % 7;
|
|
114
|
+
if (end !== 0) {
|
|
115
|
+
for (let i = 1; i <= 7 - end; i++) {
|
|
116
|
+
nextDays.push(new DayClass(i, this.isToday(nextMonth, i), false, false));
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
this.previousDays = previousDays;
|
|
120
|
+
this.nextDays = nextDays;
|
|
121
|
+
this.days = days;
|
|
122
|
+
}
|
|
123
|
+
isToday(m, d) {
|
|
124
|
+
const month = parseInt(m.format('jMM'), 10);
|
|
125
|
+
const year = parseInt(m.format('jYYYY'), 10);
|
|
126
|
+
return year === this.todayYear && month === this.todayMonth && d === this.todayDay;
|
|
127
|
+
}
|
|
128
|
+
isActive(m, d) {
|
|
129
|
+
var _a, _b;
|
|
130
|
+
const month = m.format('jMM');
|
|
131
|
+
const year = m.format('jYYYY');
|
|
132
|
+
const date = moment(year.slice(-4) + '/' + month.slice(-2) + '/' + d.toString().slice(-2), 'jYYYY/jMM/jDD');
|
|
133
|
+
for (const al of this.inp.allowed) {
|
|
134
|
+
const start = (_a = al.start) !== null && _a !== void 0 ? _a : null;
|
|
135
|
+
const end = (_b = al.end) !== null && _b !== void 0 ? _b : null;
|
|
136
|
+
if (start !== null && date < start) {
|
|
137
|
+
continue;
|
|
138
|
+
}
|
|
139
|
+
if (end !== null && date > end) {
|
|
140
|
+
continue;
|
|
141
|
+
}
|
|
142
|
+
return true;
|
|
143
|
+
}
|
|
144
|
+
return false;
|
|
145
|
+
}
|
|
146
|
+
isSelected(m, d) {
|
|
147
|
+
if (this.inp.value == null) {
|
|
148
|
+
return false;
|
|
149
|
+
}
|
|
150
|
+
const month = parseInt(m.format('jMM'), 10);
|
|
151
|
+
const year = parseInt(m.format('jYYYY'), 10);
|
|
152
|
+
const vDay = parseInt(this.inp.value.split('/')[2], 10);
|
|
153
|
+
const vMonth = parseInt(this.inp.value.split('/')[1], 10);
|
|
154
|
+
const vYear = parseInt(this.inp.value.split('/')[0], 10);
|
|
155
|
+
return year === vYear && month === vMonth && d === vDay;
|
|
156
|
+
}
|
|
157
|
+
add(c) {
|
|
158
|
+
this.active.add(c, this.state === 'day' ? 'month' : 'year');
|
|
159
|
+
this.setDate();
|
|
160
|
+
}
|
|
161
|
+
changeMonth(c) {
|
|
162
|
+
const v = moment(this.active.format('jYYYY') + '/' + ('0' + c).slice(-2) + '/' + this.active.format('jDD'), 'jYYYY/jMM/jDD');
|
|
163
|
+
this.active = v.isValid() ? v : moment(this.active.format('jYYYY') + '/' + ('0' + c).slice(-2) + '/29', 'jYYYY/jMM/jDD');
|
|
164
|
+
this.setDate();
|
|
165
|
+
if (this.inp.type === InputType.Month) {
|
|
166
|
+
this.selectDate(this.days[0]);
|
|
167
|
+
}
|
|
168
|
+
else {
|
|
169
|
+
this.changeState('day');
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
changeYear(c) {
|
|
173
|
+
const v = moment(('000' + c).slice(-4) + '/' + this.active.format('jMM') + '/' + this.active.format('jDD'), 'jYYYY/jMM/jDD');
|
|
174
|
+
this.active = v.isValid() ? v : moment(('000' + c).slice(-4) + '/' + this.active.format('jMM') + '/29', 'jYYYY/jMM/jDD');
|
|
175
|
+
this.setDate();
|
|
176
|
+
if (this.inp.type === InputType.Year) {
|
|
177
|
+
this.selectDate(this.days[0]);
|
|
178
|
+
}
|
|
179
|
+
else {
|
|
180
|
+
this.changeState('month');
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
toggleCalendar() {
|
|
184
|
+
this.openCalendar();
|
|
185
|
+
}
|
|
186
|
+
openCalendar() {
|
|
187
|
+
this.setPosition();
|
|
188
|
+
$(this.inputBase.nativeElement).focus();
|
|
189
|
+
}
|
|
190
|
+
onKeyDown(e) {
|
|
191
|
+
const code = e.keyCode || e.which;
|
|
192
|
+
if (code === 9 || code === 13) {
|
|
193
|
+
e.preventDefault();
|
|
194
|
+
$(this.inputDiv.nativeElement).removeClass('top');
|
|
195
|
+
this.changeIndex.emit(code === 9 ? e.shiftKey ? 'ShiftTab' : 'Tab' : e.shiftKey ? 'ShiftEnter' : 'Enter');
|
|
196
|
+
if (!this.inForm) {
|
|
197
|
+
$(this.inputBase.nativeElement).blur();
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
onKeyUp(e) {
|
|
202
|
+
if (this.cSearch !== e.target.value) {
|
|
203
|
+
this.inp.error = null;
|
|
204
|
+
this.inp.value = null;
|
|
205
|
+
this.cSearch = e.target.value;
|
|
206
|
+
if (this.inp.type === InputType.Year || this.inp.type === InputType.Month) {
|
|
207
|
+
if (this.inp.onChange) {
|
|
208
|
+
this.inp.onChange(this.inp);
|
|
209
|
+
}
|
|
210
|
+
return;
|
|
211
|
+
}
|
|
212
|
+
if (this.inp.search !== '' && this.inp.search !== null) {
|
|
213
|
+
const v = moment(this.inp.search, 'jYYYY/jMM/jDD');
|
|
214
|
+
if (v.isValid() && this.inp.search.length <= 10) {
|
|
215
|
+
this.active = v;
|
|
216
|
+
this.inp.value = this.active.format('jYYYY/jMM/jDD');
|
|
217
|
+
this.setDate();
|
|
218
|
+
if (this.inp.onChange) {
|
|
219
|
+
this.inp.onChange(this.inp);
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
else {
|
|
223
|
+
this.setDate();
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
else {
|
|
227
|
+
this.setDate();
|
|
228
|
+
if (this.inp.onChange) {
|
|
229
|
+
this.inp.onChange(this.inp);
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
onFocusOut() {
|
|
235
|
+
$(this.inputDiv.nativeElement).removeClass('top');
|
|
236
|
+
this.inp.search = this.inp.value != null ?
|
|
237
|
+
(this.inp.type === InputType.Year ?
|
|
238
|
+
moment(this.inp.value, 'jYYYY/jMM/jDD').locale('fa').format('jYYYY') :
|
|
239
|
+
this.inp.type === InputType.Month ?
|
|
240
|
+
moment(this.inp.value, 'jYYYY/jMM/jDD').locale('fa').format('jMMMM jYYYY') :
|
|
241
|
+
this.inp.value)
|
|
242
|
+
: null;
|
|
243
|
+
this.state = this.inp.type === InputType.Year ? 'year' : this.inp.type === InputType.Month ? 'month' : 'day';
|
|
244
|
+
}
|
|
245
|
+
setPosition() {
|
|
246
|
+
const rect = this.inputDiv.nativeElement.getBoundingClientRect();
|
|
247
|
+
const offsetOfBottom = window.innerHeight - rect.bottom;
|
|
248
|
+
const height = this.inputCalendarDiv.nativeElement.offsetHeight;
|
|
249
|
+
if (offsetOfBottom < height) {
|
|
250
|
+
$(this.inputDiv.nativeElement).addClass('top');
|
|
251
|
+
}
|
|
252
|
+
else {
|
|
253
|
+
$(this.inputDiv.nativeElement).removeClass('top');
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
selectDate(d) {
|
|
257
|
+
this.inp.error = null;
|
|
258
|
+
const s = this.days.find(x => x.selected);
|
|
259
|
+
if (s) {
|
|
260
|
+
s.selected = false;
|
|
261
|
+
}
|
|
262
|
+
const m = parseInt(this.active.format('jMM'), 10);
|
|
263
|
+
const y = parseInt(this.active.format('jYYYY'), 10);
|
|
264
|
+
this.setValue(y, m, d.day);
|
|
265
|
+
d.selected = true;
|
|
266
|
+
this.cSearch = this.inp.search;
|
|
267
|
+
setTimeout(() => {
|
|
268
|
+
$(this.inputDiv.nativeElement).removeClass('top');
|
|
269
|
+
this.changeIndex.emit('Tab');
|
|
270
|
+
if (!this.inForm) {
|
|
271
|
+
$(this.inputBase.nativeElement).blur();
|
|
272
|
+
}
|
|
273
|
+
}, 10);
|
|
274
|
+
if (this.inp.onChange) {
|
|
275
|
+
this.inp.onChange(this.inp);
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
setValue(y, m, d) {
|
|
279
|
+
this.inp.value = y + '/' + (m > 9 ? m : '0' + m) + '/' + (d > 9 ? d : '0' + d);
|
|
280
|
+
this.inp.search = this.inp.type === InputType.Year ? y :
|
|
281
|
+
this.inp.type === InputType.Month ?
|
|
282
|
+
this.months[m - 1] + ' ' + y :
|
|
283
|
+
y + '/' + (m > 9 ? m : '0' + m) + '/' + (d > 9 ? d : '0' + d);
|
|
284
|
+
}
|
|
285
|
+
changeState(s) {
|
|
286
|
+
this.state = s;
|
|
287
|
+
}
|
|
288
|
+
getYears() {
|
|
289
|
+
const y = parseInt(this.active.format('jYYYY'), 10);
|
|
290
|
+
const sy = y - (y % 20);
|
|
291
|
+
return Array.from({ length: 20 }, (x, i) => sy + i);
|
|
292
|
+
}
|
|
293
|
+
getActiveMonth() {
|
|
294
|
+
return this.months[parseInt(this.active.format('jM'), 10) - 1];
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
FormDateComponent.decorators = [
|
|
298
|
+
{ type: Component, args: [{
|
|
299
|
+
selector: 'lib-form-date',
|
|
300
|
+
template: "<div #inputDiv [id]=\"inp.id + 'DateInput'\" [style]=\"inp.style\" [className]=\"'form-input-con date w-100' + (inp.error == null ? '' : ' error') + (inp.disabled ? ' disabled' : '') + ' ' + inp.class\">\r\n <div class=\"form-input\" (click)=\"toggleCalendar()\">\r\n <div *ngIf=\"inp.displayLabel\" class=\"label\"><i *ngIf=\"inp.required\" class=\"fas fa-star-of-life required-icon\"></i>{{inp.getLabel()}}</div>\r\n <div class=\"w-100 p-r\">\r\n <i *ngIf=\"inp.icon != null || inp.loading\" #inputIcon [className]=\"(inp.loading ? 'fad fa-spin fa-spinner' : inp.icon) + ' icon'\"></i>\r\n <i *ngIf=\"inp.withClear && inp.value\" (click)=\"inp.clear()\" class=\"fad fa-times clear-icon\"></i>\r\n <input (keydown)=\"onKeyDown($event)\" (keyup)=\"onKeyUp($event)\" (focusout)=\"onFocusOut()\" [disabled]=\"inp.disabled\" [(ngModel)]=\"inp.search\" #inputBase [name]=\"inp.name\" [placeholder]=\"inp.l(inp.name)\" class=\"control\" autocomplete=\"off\" maxlength=\"\">\r\n <div #inputCalendarDiv class=\"calendar\">\r\n <div class=\"header\">\r\n <i (click)=\"add(state === 'day' || state === 'month' ? -1 : -20)\" class=\"fas fa-angle-right previous-month\"></i>\r\n <div class=\"title d-f-c\">\r\n <div (click)=\"(state === 'day' || state === 'month') && changeState('year')\" class=\"year header-item\">\r\n {{active.format('jYYYY')}}\r\n </div>\r\n <div *ngIf=\"inp.type != type.Year\" (click)=\"state === 'day' && changeState('month')\" class=\"month m-r-5-p header-item\">\r\n {{getActiveMonth()}}\r\n </div>\r\n </div>\r\n <i (click)=\"add(state === 'day' || state === 'month' ? 1 : 20)\" class=\"fas fa-angle-left next-month\"></i>\r\n </div>\r\n <div [style]=\"state === 'day' ? {} : {display: 'none'}\" class=\"days-con\">\r\n <div class=\"day-names underline\">\r\n <div class=\"item\">\u0634</div>\r\n <div class=\"item\">\u06CC</div>\r\n <div class=\"item\">\u062F</div>\r\n <div class=\"item\">\u0633</div>\r\n <div class=\"item\">\u0686</div>\r\n <div class=\"item\">\u067E</div>\r\n <div class=\"item\">\u062C</div>\r\n </div>\r\n <div class=\"days\">\r\n <div [className]=\"'item not-in-month' + (d.today ? ' today' : '')\" *ngFor=\"let d of previousDays\">{{d.day}}</div>\r\n <div (click)=\"d.active && selectDate(d)\" [className]=\"'item' + (d.today ? ' today' : '') + (d.selected ? ' selected' : '') + (!d.active ? ' not-in-month' : '')\" *ngFor=\"let d of days\">{{d.day}}</div>\r\n <div [className]=\"'item not-in-month' + (d.today ? ' today' : '')\" *ngFor=\"let d of nextDays\">{{d.day}}</div>\r\n </div>\r\n </div>\r\n <div [style]=\"state === 'month' ? {} : {display: 'none'}\" class=\"months-con\">\r\n <div [className]=\"(i + 1 == active.format('jM') ? 'selected ' : '') + 'month'\" (click)=\"changeMonth(i + 1)\" *ngFor=\"let m of months; let i = index\">{{m}}</div>\r\n </div>\r\n <div [style]=\"state === 'year' ? {} : {display: 'none'}\" class=\"years-con\">\r\n <div [className]=\"(y == active.format('jYYYY') ? 'selected ' : '') + 'year'\" (click)=\"changeYear(y)\" *ngFor=\"let y of getYears()\">{{y}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n",
|
|
301
|
+
styles: [".form-input-con.date{padding:0 15px;position:relative}.form-input-con.date .form-input{float:right;position:relative;width:100%}.form-input-con.date .form-input .label{-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-user-select:none;cursor:default;direction:rtl;float:right;font-size:12px;height:20px;line-height:20px;margin-bottom:3px;padding:0 10px;text-align:right;width:100%}.form-input-con.date.error .form-input .label{color:var(--red);font-size:10px}.form-input-con.date .form-input .label .required-icon{color:var(--red);font-size:9px;height:20px;line-height:20px;text-align:center;width:20px}.form-input-con.date .form-input .control{background-color:#fff;background-image:none;border:none;border:var(--border-input);border-radius:var(--border-radius-base);color:var(--black);display:block;font-size:11px;height:35px;padding:5px 35px;position:relative;text-align:center;width:100%;z-index:2}.form-input-con.date .form-input .control:focus{border-radius:var(--border-radius-base) var(--border-radius-base) var(--border-radius-base) 0}.form-input-con.date.top .form-input .control:focus{border-radius:0 var(--border-radius-base) var(--border-radius-base) var(--border-radius-base)}.form-input-con.date .form-input .control:focus,.form-input-con.date .form-input:hover .control{border:var(--border-input-dark);outline:none}.form-input-con.date .form-input i.icon{color:var(--primary);cursor:text;font-size:13px;left:0}.form-input-con.date .form-input i.clear-icon,.form-input-con.date .form-input i.icon{bottom:0;height:35px;line-height:35px;position:absolute;text-align:center;transition:all .35s ease-in-out;width:35px;z-index:3}.form-input-con.date .form-input i.clear-icon{color:var(--red);cursor:pointer;font-size:14px;right:0}.form-input-con.date.error .form-input .control,.form-input-con.date.error .form-input i.icon{color:var(--red-light)}.form-input-con.date.error .form-input .control{border:var(--border-input-red)}.form-input-con.date.error .form-input .control:focus,.form-input-con.date.error .form-input:hover .control{border:var(--border-input-red-dark)}.form-input-con.date .form-input .calendar{-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-user-select:none;background-color:#fff;border:var(--border-input);border-radius:0 0 var(--border-radius-base) var(--border-radius-base);color:var(--black);height:235px;left:0;overflow:hidden;position:absolute;top:-200000px;width:200px;z-index:102}.form-input-con.date .form-input .control:focus+.calendar{top:35px!important}.form-input-con.date.top .form-input .control:focus+.calendar{border-radius:var(--border-radius-base) var(--border-radius-base) 0 0;bottom:35px;top:unset!important}.form-input-con.date.disabled{-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-user-select:none;box-shadow:unset;cursor:default;filter:blur(.5px);opacity:.7;pointer-events:none}.form-input-con.date .form-input .days-con{float:right;width:100%}.form-input-con.date .form-input .calendar .header{background:var(--black-white);float:right;width:100%}.form-input-con.date .form-input .calendar .header .next-month,.form-input-con.date .form-input .calendar .header .previous-month{cursor:pointer;float:right;font-size:15px;height:30px;line-height:30px;text-align:center;width:30px}.form-input-con.date .form-input .calendar .header .next-month:hover,.form-input-con.date .form-input .calendar .header .previous-month:hover{background:var(--black-white)}.form-input-con.date .form-input .calendar .header .title{float:right;font-size:12px;font-weight:var(--font-bold);height:30px;line-height:30px;text-align:center;width:calc(100% - 60px)}.form-input-con.date .form-input .calendar .header .header-item{background-color:#fff;border:var(--border-input);border-radius:var(--border-radius-base);cursor:pointer;float:right;height:20px;line-height:20px;text-align:center}.form-input-con.date .form-input .calendar .header .header-item:hover{background-color:var(--base-white)}.form-input-con.date .form-input .calendar .header .header-item.year{width:calc(40% - 10px)}.form-input-con.date .form-input .calendar .header .header-item.month{width:calc(60% - 10px)}.form-input-con.date .form-input .calendar .days-con .day-names{float:right;font-size:12px;font-weight:var(--font-light);position:relative;text-align:center;width:100%}.form-input-con.date .form-input .calendar .days-con .day-names .item{float:right;font-size:12px;height:25px;line-height:25px;text-align:center;width:14.28571%}.form-input-con.date .form-input .calendar .days-con .days{float:right;font-size:12px;text-align:center;width:100%}.form-input-con.date .form-input .calendar .days-con .days .item{cursor:pointer;float:right;font-size:11px;height:30px;line-height:30px;text-align:center;width:14.28571%}.form-input-con.date .form-input .calendar .days-con .days .item.not-in-month{background-color:unset!important;cursor:default;opacity:.5}.form-input-con.date .form-input .calendar .days-con .days .item:hover{background-color:var(--black-white)}.form-input-con.date .form-input .calendar .days-con .days .item.not-in-month:hover{background-color:unset}.form-input-con.date .form-input .calendar .days-con .days .item.today{background-color:var(--black-white)}.form-input-con.date .form-input .calendar .days-con .days .item.selected{background-color:var(--primary);color:#fff}.form-input-con.date .form-input .calendar .months-con{float:right;width:100%}.form-input-con.date .form-input .calendar .months-con .month{cursor:pointer;float:right;font-size:11px;height:51.25px;line-height:51.25px;text-align:center;width:33.33333%}.form-input-con.date .form-input .calendar .months-con .month.selected,.form-input-con.date .form-input .calendar .months-con .month:hover{background-color:var(--black-white)}.form-input-con.date .form-input .calendar .years-con{float:right;width:100%}.form-input-con.date .form-input .calendar .years-con .year{cursor:pointer;float:right;font-size:11px;height:41px;line-height:41px;text-align:center;width:25%}.form-input-con.date .form-input .calendar .years-con .year.selected,.form-input-con.date .form-input .calendar .years-con .year:hover{background-color:var(--black-white)}.form-input-con.date.table-search{float:right;width:100%}.form-input-con.date.h-30 .form-input .control{height:30px;padding:5px 30px}.form-input-con.date.h-30 .form-input i.icon{height:30px;line-height:30px;width:30px}.form-input-con.date.h-30 .form-input .control:focus+.calendar{top:30px!important}.form-input-con.date.top.h-30 .form-input .control:focus+.calendar{bottom:30px}.form-input-con.date.h-25 .form-input .control{height:25px;padding:5px}.form-input-con.date.h-25 .form-input i.icon{display:none}.form-input-con.date.h-25 .form-input .control:focus+.calendar{top:25px!important}.form-input-con.date.top.h-25 .form-input .control:focus+.calendar{bottom:25px}.form-input-con.date.h-25 .form-input .control::-moz-placeholder,.form-input-con.date.h-25 .form-input .control::-webkit-input-placeholder{font-size:10px;font-weight:var(--font-light)}"]
|
|
302
|
+
},] }
|
|
303
|
+
];
|
|
304
|
+
FormDateComponent.ctorParameters = () => [];
|
|
305
|
+
FormDateComponent.propDecorators = {
|
|
306
|
+
inp: [{ type: Input }],
|
|
307
|
+
inForm: [{ type: Input }],
|
|
308
|
+
changeIndex: [{ type: Output }],
|
|
309
|
+
inputBase: [{ type: ViewChild, args: ['inputBase',] }],
|
|
310
|
+
inputDiv: [{ type: ViewChild, args: ['inputDiv',] }],
|
|
311
|
+
inputLabel: [{ type: ViewChild, args: ['inputLabel',] }],
|
|
312
|
+
inputCalendarDiv: [{ type: ViewChild, args: ['inputCalendarDiv',] }]
|
|
313
|
+
};
|
|
314
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.date.component.js","sourceRoot":"D:/PsToolkit/UI/projects/ps-toolkit-ui/src/","sources":["lib/components/form/date/form.date.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAc,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAC,MAAM,eAAe,CAAC;AACpG,OAAO,KAAK,MAAM,MAAM,eAAe,CAAC;AACxC,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAC,QAAQ,EAAa,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAC,UAAU,EAAE,SAAS,EAAC,MAAM,6BAA6B,CAAC;AAOlE,MAAM,OAAO,iBAAiB;IAsB5B;QAhBA,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QACzC,iBAAY,GAAe,EAAE,CAAC;QAC9B,aAAQ,GAAe,EAAE,CAAC;QAC1B,SAAI,GAAe,EAAE,CAAC;QAItB,YAAO,GAAG,EAAE,CAAC;QACb,UAAK,GAAG,KAAK,CAAC;QACd,WAAM,GAAG,CAAC,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;QACjH,WAAM,GAAkB,MAAM,EAAE,CAAC;IAOjC,CAAC;IAND,IAAI,IAAI,KAAuB,OAAO,SAAS,CAAC,CAAC,CAAC;IAOlD,QAAQ;QACN,MAAM,KAAK,GAAG,MAAM,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;QAClD,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;QACpD,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;QACrD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;QAC7G,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,GAAG,CAAC,QAAQ,GAAG,CAAC,CAAC,EAAE,EAAE;YACxB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,GAAG,EAAE;YACtB,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC;YACtB,IAAI,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE;gBACxC,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC;gBACrC,OAAO,KAAK,CAAC;aACd;YACD,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE;gBACzC,OAAO,IAAI,CAAC;aACb;YACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC,OAAO,EAAE,EAAE;gBACtD,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC;gBACpC,OAAO,KAAK,CAAC;aACd;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,GAAG,EAAE;YACpB,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC;YACtB,IAAI,IAAI,CAAC,GAAG,CAAC,OAAO,EAAC;gBACnB,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;aAC5C;iBAAI;gBACH,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC;gBACtB,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC;aACxB;YACD,IAAI,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAC;gBACpB,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aAC7B;QACH,CAAC,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,EAAE;YACnB,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC3G,CAAC,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,GAAG,EAAE;YACpB,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,QAAQ,GAAG,GAAG,EAAE;YACvB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,IAAI,EAAE,CAAC;QACzC,CAAC,CAAC;IACJ,CAAC;IACD,WAAW,CAAC,CAAC;QACX,IAAI,CAAC,KAAK,IAAI,EAAC;YACb,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACpC,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,OAAO;SACR;aAAM,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,CAAC,MAAM,KAAK,EAAE,EAAE;YACnD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;SACpD;aAAM,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE;YAChC,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACrD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;SACtC;aAAK,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAC;YAC9B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,EAAE,cAAc,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;SAChK;aAAK;YACJ,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;SACjB;QACD,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QACrD,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QACtK,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;QAC7G,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IACD,OAAO;QACL,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,eAAe,GAAG,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;QACrD,MAAM,SAAS,GAAG,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC;QAC/D,MAAM,aAAa,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QAC7C,MAAM,uBAAuB,GAAG,aAAa,CAAC,WAAW,EAAE,CAAC;QAC5D,MAAM,SAAS,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QACpC,MAAM,YAAY,GAAe,EAAE,CAAC;QACpC,MAAM,QAAQ,GAAG,EAAE,CAAC;QACpB,MAAM,IAAI,GAAG,EAAE,CAAC;QAChB,IAAI,SAAS,KAAK,CAAC,EAAC;YAClB,KAAK,IAAI,CAAC,GAAG,uBAAuB,GAAG,SAAS,EAAE,CAAC,IAAI,uBAAuB,EAAE,CAAC,EAAE,EAAC;gBAClF,YAAY,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;aAClF;SACF;QACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,eAAe,EAAE,CAAC,EAAE,EAAC;YACxC,IAAI,QAAQ,GAAG,IAAI,CAAC;YACpB,IAAI,IAAI,CAAC,GAAG,CAAC,OAAO,IAAI,IAAI,IAAI,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAC;gBAC1D,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;aAC1C;YACD,IAAI,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC;SACrG;QACD,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACpD,IAAI,GAAG,KAAK,CAAC,EAAC;YACZ,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAC;gBAChC,QAAQ,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;aAC1E;SACF;QACD,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IACD,OAAO,CAAC,CAAgB,EAAE,CAAS;QACjC,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;QAC5C,MAAM,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;QAC7C,OAAO,IAAI,KAAK,IAAI,CAAC,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC,UAAU,IAAI,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC;IACrF,CAAC;IACD,QAAQ,CAAC,CAAgB,EAAE,CAAS;;QAClC,MAAM,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC9B,MAAM,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC/B,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC;QAC5G,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,GAAG,CAAC,OAAO,EAAC;YAChC,MAAM,KAAK,SAAG,EAAE,CAAC,KAAK,mCAAI,IAAI,CAAC;YAC/B,MAAM,GAAG,SAAG,EAAE,CAAC,GAAG,mCAAI,IAAI,CAAC;YAC3B,IAAI,KAAK,KAAK,IAAI,IAAI,IAAI,GAAG,KAAK,EAAC;gBACjC,SAAS;aACV;YACD,IAAI,GAAG,KAAK,IAAI,IAAI,IAAI,GAAG,GAAG,EAAC;gBAC7B,SAAS;aACV;YACD,OAAO,IAAI,CAAC;SACb;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,UAAU,CAAC,CAAgB,EAAE,CAAS;QACpC,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,IAAI,EAAC;YACzB,OAAO,KAAK,CAAC;SACd;QACD,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;QAC5C,MAAM,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;QAC7C,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACxD,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC1D,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACzD,OAAO,IAAI,KAAK,KAAK,IAAI,KAAK,KAAK,MAAM,IAAI,CAAC,KAAK,IAAI,CAAC;IAC1D,CAAC;IACD,GAAG,CAAC,CAAS;QACX,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAC5D,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IACD,WAAW,CAAC,CAAS;QACnB,MAAM,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,eAAe,CAAC,CAAC;QAC7H,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE,eAAe,CAAC,CAAC;QACzH,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,KAAK,EAAC;YACpC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;SAC/B;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;SACzB;IACH,CAAC;IACD,UAAU,CAAC,CAAS;QAClB,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,eAAe,CAAC,CAAC;QAC7H,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,KAAK,EAAE,eAAe,CAAC,CAAC;QACzH,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,EAAC;YACnC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;SAC/B;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;SAC3B;IACH,CAAC;IACD,cAAc;QACZ,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IACD,YAAY;QACV,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,KAAK,EAAE,CAAC;IAC1C,CAAC;IACD,SAAS,CAAC,CAAC;QACT,MAAM,IAAI,GAAG,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,KAAK,CAAC;QAClC,IAAI,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,EAAE,EAAE;YAC7B,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAClD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;YAC1G,IAAI,CAAC,IAAI,CAAC,MAAM,EAAC;gBACf,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,IAAI,EAAE,CAAC;aACxC;SACF;IACH,CAAC;IACD,OAAO,CAAC,CAAC;QACP,IAAI,IAAI,CAAC,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE;YACnC,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;YAC9B,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,KAAK,EAAC;gBACxE,IAAI,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAC;oBACpB,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;iBAC7B;gBACD,OAAO;aACR;YACD,IAAI,IAAI,CAAC,GAAG,CAAC,MAAM,KAAK,EAAE,IAAI,IAAI,CAAC,GAAG,CAAC,MAAM,KAAK,IAAI,EAAC;gBACrD,MAAM,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;gBACnD,IAAI,CAAC,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE,EAAC;oBAC9C,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;oBAChB,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;oBACrD,IAAI,CAAC,OAAO,EAAE,CAAC;oBACf,IAAI,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAC;wBACpB,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;qBAC7B;iBACF;qBAAI;oBACH,IAAI,CAAC,OAAO,EAAE,CAAC;iBAChB;aACF;iBAAM;gBACL,IAAI,CAAC,OAAO,EAAE,CAAC;gBACf,IAAI,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAC;oBACpB,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;iBAC7B;aACF;SACF;IACH,CAAC;IACD,UAAU;QACR,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAClD,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC;YACxC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,CAAC,CAAC;gBACjC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;gBACtE,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,KAAK,CAAC,CAAC;oBACjC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC;oBAC5E,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC;YACnB,CAAC,CAAC,IAAI,CAAC;QACT,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;IAC/G,CAAC;IACD,WAAW;QACT,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;QACjE,MAAM,cAAc,GAAG,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC;QACxD,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,YAAY,CAAC;QAChE,IAAI,cAAc,GAAG,MAAM,EAAC;YAC1B,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SAChD;aAAI;YACH,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;SACnD;IACH,CAAC;IACD,UAAU,CAAC,CAAW;QACpB,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC;QACtB,MAAM,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;QAC1C,IAAI,CAAC,EAAC;YACJ,CAAC,CAAC,QAAQ,GAAG,KAAK,CAAC;SACpB;QACD,MAAM,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;QAClD,MAAM,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;QACpD,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;QAC3B,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC;QAC/B,UAAU,CAAC,GAAG,EAAE;YACd,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAClD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC7B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAC;gBACf,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,IAAI,EAAE,CAAC;aACxC;QACH,CAAC,EAAE,EAAE,CAAC,CAAC;QACP,IAAI,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAC;YACpB,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAC7B;IACH,CAAC;IACD,QAAQ,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS;QACtC,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;QAC/E,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACtD,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,KAAK,CAAC,CAAC;gBACjC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;gBAC9B,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;IACpE,CAAC;IACD,WAAW,CAAC,CAAS;QACnB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IACjB,CAAC;IACD,QAAQ;QACN,MAAM,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;QACpD,MAAM,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;QACxB,OAAO,KAAK,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,EAAE,EAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;IACpD,CAAC;IACD,cAAc;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IACjE,CAAC;;;YAvSF,SAAS,SAAC;gBACT,QAAQ,EAAE,eAAe;gBACzB,k5GAAyC;;aAE1C;;;;kBAEE,KAAK;qBAEL,KAAK;0BAEL,MAAM;wBAaN,SAAS,SAAC,WAAW;uBACrB,SAAS,SAAC,UAAU;yBACpB,SAAS,SAAC,YAAY;+BACtB,SAAS,SAAC,kBAAkB","sourcesContent":["import {Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild} from '@angular/core';\r\nimport * as moment from 'jalali-moment';\r\nimport * as $ from 'jquery';\r\nimport {DayClass, InputClass} from '../../../classes/form.class';\r\nimport {InputError, InputType} from '../../../classes/enum.class';\r\n\r\n@Component({\r\n  selector: 'lib-form-date',\r\n  templateUrl: './form.date.component.html',\r\n  styleUrls: ['./form.date.component.css']\r\n})\r\nexport class FormDateComponent implements OnInit{\r\n  @Input()\r\n  inp: InputClass;\r\n  @Input()\r\n  inForm: boolean;\r\n  @Output()\r\n  changeIndex = new EventEmitter<string>();\r\n  previousDays: DayClass[] = [];\r\n  nextDays: DayClass[] = [];\r\n  days: DayClass[] = [];\r\n  todayDay: number;\r\n  todayMonth: number;\r\n  todayYear: number;\r\n  cSearch = '';\r\n  state = 'day';\r\n  months = ['فروردین', 'اردیبهشت', 'خرداد', 'تیر', 'مرداد', 'شهریور', 'مهر', 'آبان', 'آذر', 'دی', 'بهمن', 'اسفند'];\r\n  active: moment.Moment = moment();\r\n  get type(): typeof InputType { return InputType; }\r\n  @ViewChild('inputBase') inputBase: ElementRef;\r\n  @ViewChild('inputDiv') inputDiv: ElementRef;\r\n  @ViewChild('inputLabel') inputLabel: ElementRef;\r\n  @ViewChild('inputCalendarDiv') inputCalendarDiv: ElementRef;\r\n  constructor(){\r\n  }\r\n  ngOnInit(): void{\r\n    const today = moment().locale('fa');\r\n    this.todayDay = parseInt(today.format('jDD'), 10);\r\n    this.todayMonth = parseInt(today.format('jMM'), 10);\r\n    this.todayYear = parseInt(today.format('jYYYY'), 10);\r\n    this.state = this.inp.type === InputType.Year ? 'year' : this.inp.type === InputType.Month ? 'month' : 'day';\r\n    this.setInpValue(this.inp.value);\r\n    this.inp.setValue = (v) => {\r\n      this.setInpValue(v);\r\n    };\r\n    this.inp.isValid = () => {\r\n      this.inp.error = null;\r\n      if (this.inp.required && !this.inp.value) {\r\n        this.inp.error = InputError.Required;\r\n        return false;\r\n      }\r\n      if (!this.inp.required && !this.inp.value) {\r\n        return true;\r\n      }\r\n      if (!moment(this.inp.value, 'jYYYY/jMM/jDD').isValid()) {\r\n        this.inp.error = InputError.Invalid;\r\n        return false;\r\n      }\r\n      return true;\r\n    };\r\n    this.inp.clear = () => {\r\n      this.inp.error = null;\r\n      if (this.inp.default){\r\n        this.inp.setValue(this.inp.default, false);\r\n      }else{\r\n        this.inp.value = null;\r\n        this.inp.search = null;\r\n      }\r\n      if (this.inp.onChange){\r\n        this.inp.onChange(this.inp);\r\n      }\r\n    };\r\n    this.inp.data = () => {\r\n      return this.inp.value ? moment(this.inp.value, 'jYYYY/jMM/jDD').locale('en').format('YYYY/MM/DD') : null;\r\n    };\r\n    this.inp.focus = () => {\r\n      this.openCalendar();\r\n    };\r\n    this.inp.focusOut = () => {\r\n      $(this.inputBase.nativeElement).blur();\r\n    };\r\n  }\r\n  setInpValue(v): void{\r\n    if (v === null){\r\n      this.inp.clear();\r\n      this.active = moment().locale('fa');\r\n      this.setDate();\r\n      return;\r\n    } else if (typeof v === 'string' && v.length === 10) {\r\n      this.active = moment(v, 'YYYY/MM/DD').locale('fa');\r\n    } else if (typeof v === 'string') {\r\n      const d = parseInt(v.substring(6, v.length - 2), 10);\r\n      this.active = moment(d).locale('fa');\r\n    }else if (typeof v === 'number'){\r\n      this.active = this.inp.type === InputType.Month ? moment(moment(v).locale('fa').format('jYYYY/jMM/jDD'), 'jYYYY/jMM/01').locale('fa') : moment(v).locale('fa');\r\n    }else {\r\n      this.active = v;\r\n    }\r\n    this.inp.value = this.active.format('jYYYY/jMM/jDD');\r\n    this.inp.search = this.cSearch = this.active.format(this.inp.type === InputType.Year ? 'jYYYY' : this.inp.type === InputType.Month ? 'jMMMM jYYYY' : 'jYYYY/jMM/jDD');\r\n    this.state = this.inp.type === InputType.Year ? 'year' : this.inp.type === InputType.Month ? 'month' : 'day';\r\n    this.setDate();\r\n  }\r\n  setDate(): void{\r\n    const n = this.active.clone();\r\n    const countDayInMonth = n.locale('fa').daysInMonth();\r\n    const startWeek = parseInt(n.startOf('month').format('d'), 10);\r\n    const previousMonth = n.subtract(1, 'month');\r\n    const countDayInPreviousMonth = previousMonth.daysInMonth();\r\n    const nextMonth = n.add(2, 'month');\r\n    const previousDays: DayClass[] = [];\r\n    const nextDays = [];\r\n    const days = [];\r\n    if (startWeek !== 6){\r\n      for (let i = countDayInPreviousMonth - startWeek; i <= countDayInPreviousMonth; i++){\r\n        previousDays.push(new DayClass(i, this.isToday(previousMonth, i), false, false));\r\n      }\r\n    }\r\n    for (let i = 1; i <= countDayInMonth; i++){\r\n      let isActive = true;\r\n      if (this.inp.allowed != null && this.inp.allowed.length > 0){\r\n        isActive = this.isActive(this.active, i);\r\n      }\r\n      days.push(new DayClass(i, this.isToday(this.active, i), this.isSelected(this.active, i), isActive));\r\n    }\r\n    const end = (days.length + previousDays.length) % 7;\r\n    if (end !== 0){\r\n      for (let i = 1; i <= 7 - end; i++){\r\n        nextDays.push(new DayClass(i, this.isToday(nextMonth, i), false, false));\r\n      }\r\n    }\r\n    this.previousDays = previousDays;\r\n    this.nextDays = nextDays;\r\n    this.days = days;\r\n  }\r\n  isToday(m: moment.Moment, d: number): boolean{\r\n    const month = parseInt(m.format('jMM'), 10);\r\n    const year = parseInt(m.format('jYYYY'), 10);\r\n    return year === this.todayYear && month === this.todayMonth && d === this.todayDay;\r\n  }\r\n  isActive(m: moment.Moment, d: number): boolean{\r\n    const month = m.format('jMM');\r\n    const year = m.format('jYYYY');\r\n    const date = moment(year.slice(-4) + '/' + month.slice(-2) + '/' + d.toString().slice(-2), 'jYYYY/jMM/jDD');\r\n    for (const al of this.inp.allowed){\r\n      const start = al.start ?? null;\r\n      const end = al.end ?? null;\r\n      if (start !== null && date < start){\r\n        continue;\r\n      }\r\n      if (end !== null && date > end){\r\n        continue;\r\n      }\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n  isSelected(m: moment.Moment, d: number): boolean{\r\n    if (this.inp.value == null){\r\n      return false;\r\n    }\r\n    const month = parseInt(m.format('jMM'), 10);\r\n    const year = parseInt(m.format('jYYYY'), 10);\r\n    const vDay = parseInt(this.inp.value.split('/')[2], 10);\r\n    const vMonth = parseInt(this.inp.value.split('/')[1], 10);\r\n    const vYear = parseInt(this.inp.value.split('/')[0], 10);\r\n    return year === vYear && month === vMonth && d === vDay;\r\n  }\r\n  add(c: number): void{\r\n    this.active.add(c, this.state === 'day' ? 'month' : 'year');\r\n    this.setDate();\r\n  }\r\n  changeMonth(c: number): void{\r\n    const v = moment(this.active.format('jYYYY') + '/' + ('0' + c).slice(-2) + '/' + this.active.format('jDD'), 'jYYYY/jMM/jDD');\r\n    this.active = v.isValid() ? v : moment(this.active.format('jYYYY') + '/' + ('0' + c).slice(-2) + '/29', 'jYYYY/jMM/jDD');\r\n    this.setDate();\r\n    if (this.inp.type === InputType.Month){\r\n      this.selectDate(this.days[0]);\r\n    } else {\r\n      this.changeState('day');\r\n    }\r\n  }\r\n  changeYear(c: number): void{\r\n    const v = moment(('000' + c).slice(-4) + '/' + this.active.format('jMM') + '/' + this.active.format('jDD'), 'jYYYY/jMM/jDD');\r\n    this.active = v.isValid() ? v : moment(('000' + c).slice(-4) + '/' + this.active.format('jMM') + '/29', 'jYYYY/jMM/jDD');\r\n    this.setDate();\r\n    if (this.inp.type === InputType.Year){\r\n      this.selectDate(this.days[0]);\r\n    } else {\r\n      this.changeState('month');\r\n    }\r\n  }\r\n  toggleCalendar(): void{\r\n    this.openCalendar();\r\n  }\r\n  openCalendar(): void {\r\n    this.setPosition();\r\n    $(this.inputBase.nativeElement).focus();\r\n  }\r\n  onKeyDown(e): void{\r\n    const code = e.keyCode || e.which;\r\n    if (code === 9 || code === 13) {\r\n      e.preventDefault();\r\n      $(this.inputDiv.nativeElement).removeClass('top');\r\n      this.changeIndex.emit(code === 9 ? e.shiftKey ? 'ShiftTab' : 'Tab' : e.shiftKey ? 'ShiftEnter' : 'Enter');\r\n      if (!this.inForm){\r\n        $(this.inputBase.nativeElement).blur();\r\n      }\r\n    }\r\n  }\r\n  onKeyUp(e): void{\r\n    if (this.cSearch !== e.target.value) {\r\n      this.inp.error = null;\r\n      this.inp.value = null;\r\n      this.cSearch = e.target.value;\r\n      if (this.inp.type === InputType.Year || this.inp.type === InputType.Month){\r\n        if (this.inp.onChange){\r\n          this.inp.onChange(this.inp);\r\n        }\r\n        return;\r\n      }\r\n      if (this.inp.search !== '' && this.inp.search !== null){\r\n        const v = moment(this.inp.search, 'jYYYY/jMM/jDD');\r\n        if (v.isValid() && this.inp.search.length <= 10){\r\n          this.active = v;\r\n          this.inp.value = this.active.format('jYYYY/jMM/jDD');\r\n          this.setDate();\r\n          if (this.inp.onChange){\r\n            this.inp.onChange(this.inp);\r\n          }\r\n        }else{\r\n          this.setDate();\r\n        }\r\n      } else {\r\n        this.setDate();\r\n        if (this.inp.onChange){\r\n          this.inp.onChange(this.inp);\r\n        }\r\n      }\r\n    }\r\n  }\r\n  onFocusOut(): void{\r\n    $(this.inputDiv.nativeElement).removeClass('top');\r\n    this.inp.search = this.inp.value != null ?\r\n      (this.inp.type === InputType.Year ?\r\n        moment(this.inp.value, 'jYYYY/jMM/jDD').locale('fa').format('jYYYY') :\r\n        this.inp.type === InputType.Month ?\r\n          moment(this.inp.value, 'jYYYY/jMM/jDD').locale('fa').format('jMMMM jYYYY') :\r\n          this.inp.value)\r\n      : null;\r\n    this.state = this.inp.type === InputType.Year ? 'year' : this.inp.type === InputType.Month ? 'month' : 'day';\r\n  }\r\n  setPosition(): void{\r\n    const rect = this.inputDiv.nativeElement.getBoundingClientRect();\r\n    const offsetOfBottom = window.innerHeight - rect.bottom;\r\n    const height = this.inputCalendarDiv.nativeElement.offsetHeight;\r\n    if (offsetOfBottom < height){\r\n      $(this.inputDiv.nativeElement).addClass('top');\r\n    }else{\r\n      $(this.inputDiv.nativeElement).removeClass('top');\r\n    }\r\n  }\r\n  selectDate(d: DayClass): void {\r\n    this.inp.error = null;\r\n    const s = this.days.find(x => x.selected);\r\n    if (s){\r\n      s.selected = false;\r\n    }\r\n    const m = parseInt(this.active.format('jMM'), 10);\r\n    const y = parseInt(this.active.format('jYYYY'), 10);\r\n    this.setValue(y, m, d.day);\r\n    d.selected = true;\r\n    this.cSearch = this.inp.search;\r\n    setTimeout(() => {\r\n      $(this.inputDiv.nativeElement).removeClass('top');\r\n      this.changeIndex.emit('Tab');\r\n      if (!this.inForm){\r\n        $(this.inputBase.nativeElement).blur();\r\n      }\r\n    }, 10);\r\n    if (this.inp.onChange){\r\n      this.inp.onChange(this.inp);\r\n    }\r\n  }\r\n  setValue(y: number, m: number, d: number): void{\r\n    this.inp.value = y + '/' + (m > 9 ? m : '0' + m) + '/' + (d > 9 ? d : '0' + d);\r\n    this.inp.search = this.inp.type === InputType.Year ? y :\r\n      this.inp.type === InputType.Month ?\r\n        this.months[m - 1] + ' ' + y :\r\n        y + '/' + (m > 9 ? m : '0' + m) + '/' + (d > 9 ? d : '0' + d);\r\n  }\r\n  changeState(s: string): void{\r\n    this.state = s;\r\n  }\r\n  getYears(): number[]{\r\n    const y = parseInt(this.active.format('jYYYY'), 10);\r\n    const sy = y - (y % 20);\r\n    return Array.from({length: 20}, (x, i) => sy + i);\r\n  }\r\n  getActiveMonth(): string{\r\n    return this.months[parseInt(this.active.format('jM'), 10) - 1];\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as moment from 'jalali-moment';
|
|
3
|
+
import { InputClass } from '../../../classes/form.class';
|
|
4
|
+
import { InputError, InputType } from '../../../classes/enum.class';
|
|
5
|
+
export class FormDatetimeComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.changeIndex = new EventEmitter();
|
|
8
|
+
}
|
|
9
|
+
ngOnInit() {
|
|
10
|
+
this.date = new InputClass(this.inp.environment, this.inp.l, 'Date', null, InputType.Date);
|
|
11
|
+
this.time = new InputClass(this.inp.environment, this.inp.l, 'Time', null, InputType.Time);
|
|
12
|
+
this.date.displayLabel = this.time.displayLabel = false;
|
|
13
|
+
this.time.level = this.inp.level;
|
|
14
|
+
if (this.inp.value) {
|
|
15
|
+
this.inp.setValue(this.inp.value, false);
|
|
16
|
+
}
|
|
17
|
+
this.inp.setValue = (v) => {
|
|
18
|
+
if (v === null) {
|
|
19
|
+
this.inp.clear();
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
else if (typeof v === 'string') {
|
|
23
|
+
v = parseInt(v.substring(6, v.length - 2), 10);
|
|
24
|
+
}
|
|
25
|
+
const m = moment(v).locale('fa');
|
|
26
|
+
this.date.setValue(m, false);
|
|
27
|
+
this.time.setValue({ Hours: m.hours(), Minutes: m.minutes() }, false);
|
|
28
|
+
};
|
|
29
|
+
this.inp.isValid = () => {
|
|
30
|
+
this.inp.value = this.getValue();
|
|
31
|
+
this.inp.error = null;
|
|
32
|
+
this.date.error = null;
|
|
33
|
+
this.time.error = null;
|
|
34
|
+
if (this.inp.required && !this.inp.value) {
|
|
35
|
+
this.inp.error = InputError.Required;
|
|
36
|
+
this.date.error = InputError.Required;
|
|
37
|
+
this.time.error = InputError.Required;
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
if (!this.inp.required && !this.inp.value) {
|
|
41
|
+
return true;
|
|
42
|
+
}
|
|
43
|
+
if (!moment(this.inp.value, 'jYYYY/jMM/jDD HH:mm').isValid()) {
|
|
44
|
+
this.inp.error = InputError.Invalid;
|
|
45
|
+
this.date.error = InputError.Invalid;
|
|
46
|
+
this.time.error = InputError.Invalid;
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
return true;
|
|
50
|
+
};
|
|
51
|
+
this.inp.clear = () => {
|
|
52
|
+
if (this.inp.default) {
|
|
53
|
+
this.inp.setValue(this.inp.default, false);
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
this.date.clear();
|
|
57
|
+
this.time.clear();
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
this.inp.data = () => {
|
|
61
|
+
const v = this.getValue();
|
|
62
|
+
return v != null ? moment(v, 'jYYYY/jMM/jDD HH:mm').locale('en').format('YYYY/MM/DD HH:mm') : null;
|
|
63
|
+
};
|
|
64
|
+
this.inp.focus = () => {
|
|
65
|
+
this.date.focus();
|
|
66
|
+
};
|
|
67
|
+
this.inp.focusOut = () => {
|
|
68
|
+
this.date.focusOut();
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
changeFocus(p, a) {
|
|
72
|
+
if (p === 'Date') {
|
|
73
|
+
if (a === 'Tab' || a === 'Enter') {
|
|
74
|
+
this.time.focus();
|
|
75
|
+
}
|
|
76
|
+
else if (a === 'ShiftTab' || a === 'ShiftEnter') {
|
|
77
|
+
this.changeIndex.emit('ShiftTab');
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
if (a === 'Tab' || a === 'Enter') {
|
|
82
|
+
this.changeIndex.emit('Tab');
|
|
83
|
+
}
|
|
84
|
+
else if (a === 'ShiftTab' || a === 'ShiftEnter') {
|
|
85
|
+
this.date.focus();
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
getValue() {
|
|
90
|
+
return !this.date.value || !this.time.value ? null : `${this.date.value} ${this.time.value}`;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
FormDatetimeComponent.decorators = [
|
|
94
|
+
{ type: Component, args: [{
|
|
95
|
+
selector: 'lib-form-datetime',
|
|
96
|
+
template: "<div [id]=\"inp.id + 'DatetimeInput'\" [style]=\"inp.style\" [className]=\"'form-input-con datetime w-100' + (inp.error == null ? '' : ' error') + (inp.disabled ? ' disabled' : '') + ' ' + inp.class\">\r\n <div class=\"form-input\">\r\n <div *ngIf=\"inp.displayLabel\" (click)=\"this.date.focus()\" class=\"label\"><i *ngIf=\"inp.required\" class=\"fas fa-star-of-life required-icon\"></i>{{inp.getLabel()}}</div>\r\n <div class=\"w-100 p-r\">\r\n <i (click)=\"this.date.focus()\" *ngIf=\"inp.icon != null || inp.loading\" #inputIcon [className]=\"(inp.loading ? 'fad fa-spin fa-spinner' : inp.icon) + ' icon'\"></i>\r\n <i *ngIf=\"inp.withClear && (date.value || time.value)\" (click)=\"inp.clear()\" class=\"fad fa-times clear-icon\"></i>\r\n <lib-form-date (changeIndex)=\"changeFocus('Date', $event)\" [inp]=\"date\"></lib-form-date>\r\n <lib-form-time (changeIndex)=\"changeFocus('Time', $event)\" [inp]=\"time\"></lib-form-time>\r\n </div>\r\n </div>\r\n</div>\r\n",
|
|
97
|
+
styles: [".form-input-con.datetime{padding:0 15px;position:relative}.form-input-con.datetime .form-input{float:right;position:relative;width:100%}.form-input-con.datetime .form-input .label{-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-user-select:none;cursor:default;direction:rtl;float:right;font-size:12px;height:20px;line-height:20px;margin-bottom:3px;padding:0 10px;text-align:right;width:100%}.form-input-con.datetime.error .form-input .label{color:var(--red);font-size:10px}.form-input-con.datetime .form-input .label .required-icon{color:var(--red);font-size:9px;height:20px;line-height:20px;text-align:center;width:20px}.form-input-con.datetime .form-input .control{background-color:#fff;background-image:none;border:none;border:var(--border-input);border-radius:var(--border-radius-base);color:var(--black);display:block;font-size:11px;height:35px;padding:5px 35px;position:relative;text-align:center;width:100%;z-index:2}.form-input-con.datetime .form-input .control:focus{border-radius:var(--border-radius-base) var(--border-radius-base) var(--border-radius-base) 0}.form-input-con.datetime.top .form-input .control:focus{border-radius:0 var(--border-radius-base) var(--border-radius-base) var(--border-radius-base)}.form-input-con.datetime .form-input .control:focus,.form-input-con.datetime .form-input:hover .control{border:var(--border-input-dark);outline:none}.form-input-con.datetime .form-input i.icon{color:var(--primary);cursor:text;font-size:13px;left:0}.form-input-con.datetime .form-input i.clear-icon,.form-input-con.datetime .form-input i.icon{bottom:0;height:35px;line-height:35px;position:absolute;text-align:center;transition:all .35s ease-in-out;width:35px;z-index:3}.form-input-con.datetime .form-input i.clear-icon{color:var(--red);cursor:pointer;font-size:14px;right:0}.form-input-con.datetime.disabled .form-input,.form-input-con.datetime.disabled .form-input .label,.form-input-con.datetime.disabled .form-input i.icon{cursor:default;filter:blur(.5px);opacity:.7;pointer-events:none}::ng-deep .form-input-con.datetime .form-input .form-input-con.date .form-input .control{padding:5px 15px 5px 35px!important;padding:5px 15px!important}::ng-deep .form-input-con.datetime.disabled .form-input .form-input-con.date .form-input .control,::ng-deep .form-input-con.datetime.disabled .form-input .form-input-con.date .form-input .label,::ng-deep .form-input-con.datetime.disabled .form-input .form-input-con.date .form-input i.icon,::ng-deep .form-input-con.datetime.disabled .form-input .form-input-con.time .form-input .control,::ng-deep .form-input-con.datetime.disabled .form-input .form-input-con.time .form-input .label,::ng-deep .form-input-con.datetime.disabled .form-input .form-input-con.time .form-input i.icon{cursor:default;filter:blur(.5px);opacity:.7;pointer-events:none}.form-input-con.datetime.error .form-input .control,.form-input-con.datetime.error .form-input i.icon{color:var(--red-light)}.form-input-con.datetime.error .form-input .control{border:var(--border-input-red)}.form-input-con.datetime.error .form-input .control:focus,.form-input-con.datetime.error .form-input:hover .control{border:var(--border-input-red-dark)}::ng-deep .form-input-con.datetime .form-input .form-input-con.date{float:left!important;padding:0;width:60%}::ng-deep .form-input-con.datetime .form-input .form-input-con.time{float:right;padding:0;width:40%}::ng-deep .form-input-con.datetime .form-input .form-input-con.date .form-input .control{border-radius:var(--border-radius-base) 0 0 var(--border-radius-base)!important}::ng-deep .form-input-con.datetime .form-input .form-input-con.time .form-input .control{border-left:unset!important;border-radius:0 var(--border-radius-base) var(--border-radius-base) 0!important}"]
|
|
98
|
+
},] }
|
|
99
|
+
];
|
|
100
|
+
FormDatetimeComponent.ctorParameters = () => [];
|
|
101
|
+
FormDatetimeComponent.propDecorators = {
|
|
102
|
+
inp: [{ type: Input }],
|
|
103
|
+
inForm: [{ type: Input }],
|
|
104
|
+
changeIndex: [{ type: Output }]
|
|
105
|
+
};
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.datetime.component.js","sourceRoot":"D:/PsToolkit/UI/projects/ps-toolkit-ui/src/","sources":["lib/components/form/datetime/form.datetime.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild} from '@angular/core';\r\nimport * as moment from 'jalali-moment';\r\nimport {InputClass} from '../../../classes/form.class';\r\nimport {InputError, InputType} from '../../../classes/enum.class';\r\n\r\n@Component({\r\n  selector: 'lib-form-datetime',\r\n  templateUrl: './form.datetime.component.html',\r\n  styleUrls: ['./form.datetime.component.css']\r\n})\r\nexport class FormDatetimeComponent implements OnInit{\r\n  @Input()\r\n  inp: InputClass;\r\n  @Input()\r\n  inForm: boolean;\r\n  @Output()\r\n  changeIndex = new EventEmitter<string>();\r\n  date: InputClass;\r\n  time: InputClass;\r\n  constructor(){\r\n  }\r\n  ngOnInit(): void{\r\n    this.date = new InputClass(this.inp.environment, this.inp.l, 'Date', null, InputType.Date);\r\n    this.time = new InputClass(this.inp.environment, this.inp.l, 'Time', null, InputType.Time);\r\n    this.date.displayLabel = this.time.displayLabel = false;\r\n    this.time.level = this.inp.level;\r\n    if (this.inp.value){\r\n      this.inp.setValue(this.inp.value, false);\r\n    }\r\n    this.inp.setValue = (v) => {\r\n      if (v === null){\r\n        this.inp.clear();\r\n        return;\r\n      } else if (typeof v === 'string') {\r\n        v = parseInt(v.substring(6, v.length - 2), 10);\r\n      }\r\n      const m = moment(v).locale('fa');\r\n      this.date.setValue(m, false);\r\n      this.time.setValue({Hours: m.hours(), Minutes: m.minutes()}, false);\r\n    };\r\n    this.inp.isValid = () => {\r\n      this.inp.value = this.getValue();\r\n      this.inp.error = null;\r\n      this.date.error = null;\r\n      this.time.error = null;\r\n      if (this.inp.required && !this.inp.value) {\r\n        this.inp.error = InputError.Required;\r\n        this.date.error = InputError.Required;\r\n        this.time.error = InputError.Required;\r\n        return false;\r\n      }\r\n      if (!this.inp.required && !this.inp.value) {\r\n        return true;\r\n      }\r\n      if (!moment(this.inp.value, 'jYYYY/jMM/jDD HH:mm').isValid()) {\r\n        this.inp.error = InputError.Invalid;\r\n        this.date.error = InputError.Invalid;\r\n        this.time.error = InputError.Invalid;\r\n        return false;\r\n      }\r\n      return true;\r\n    };\r\n    this.inp.clear = () => {\r\n      if (this.inp.default){\r\n        this.inp.setValue(this.inp.default, false);\r\n      }else{\r\n        this.date.clear();\r\n        this.time.clear();\r\n      }\r\n    };\r\n    this.inp.data = () => {\r\n      const v = this.getValue();\r\n      return v != null ? moment(v, 'jYYYY/jMM/jDD HH:mm').locale('en').format('YYYY/MM/DD HH:mm') : null;\r\n    };\r\n    this.inp.focus = () => {\r\n      this.date.focus();\r\n    };\r\n    this.inp.focusOut = () => {\r\n      this.date.focusOut();\r\n    };\r\n  }\r\n  changeFocus(p, a): void{\r\n    if (p === 'Date'){\r\n      if (a === 'Tab' || a === 'Enter'){\r\n        this.time.focus();\r\n      } else if (a === 'ShiftTab' || a === 'ShiftEnter'){\r\n        this.changeIndex.emit('ShiftTab');\r\n      }\r\n    } else {\r\n      if (a === 'Tab' || a === 'Enter'){\r\n        this.changeIndex.emit('Tab');\r\n      } else if (a === 'ShiftTab' || a === 'ShiftEnter'){\r\n        this.date.focus();\r\n      }\r\n    }\r\n  }\r\n  getValue(): string{\r\n    return !this.date.value || !this.time.value ? null : `${this.date.value} ${this.time.value}`;\r\n  }\r\n}\r\n"]}
|