@bagelink/vue 1.2.25 → 1.2.39
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/dist/components/calendar/Index.vue.d.ts +2 -1
- package/dist/components/calendar/Index.vue.d.ts.map +1 -1
- package/dist/components/calendar/views/DayView.vue.d.ts.map +1 -1
- package/dist/components/calendar/views/MonthView.vue.d.ts +162 -2
- package/dist/components/calendar/views/MonthView.vue.d.ts.map +1 -1
- package/dist/components/calendar/views/WeekView.vue.d.ts +162 -2
- package/dist/components/calendar/views/WeekView.vue.d.ts.map +1 -1
- package/dist/components/form/inputs/DateInput.vue.d.ts.map +1 -1
- package/dist/index.cjs +39 -50
- package/dist/index.mjs +39 -50
- package/dist/style.css +91 -82
- package/dist/utils/calendar/dateUtils.d.ts +18 -12
- package/dist/utils/calendar/dateUtils.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/components/calendar/Index.vue +6 -5
- package/src/components/calendar/views/AgendaView.vue +1 -1
- package/src/components/calendar/views/DayView.vue +2 -1
- package/src/components/calendar/views/MonthView.vue +23 -22
- package/src/components/calendar/views/WeekView.vue +10 -9
- package/src/components/form/inputs/DateInput.vue +14 -5
- package/src/utils/calendar/dateUtils.ts +39 -48
package/dist/style.css
CHANGED
|
@@ -310,45 +310,45 @@ display: block;
|
|
|
310
310
|
border-radius: var(--input-border-radius);
|
|
311
311
|
}
|
|
312
312
|
|
|
313
|
-
.agenda-view[data-v-
|
|
313
|
+
.agenda-view[data-v-520aee85] {
|
|
314
314
|
display: flex;
|
|
315
315
|
flex-direction: column;
|
|
316
316
|
height: 100%;
|
|
317
317
|
overflow: hidden;
|
|
318
318
|
}
|
|
319
|
-
.agenda-header[data-v-
|
|
319
|
+
.agenda-header[data-v-520aee85] {
|
|
320
320
|
display: flex;
|
|
321
321
|
padding: 0.5rem;
|
|
322
322
|
border-bottom: 1px solid var(--border-color);
|
|
323
323
|
}
|
|
324
|
-
.time-column[data-v-
|
|
324
|
+
.time-column[data-v-520aee85] {
|
|
325
325
|
width: 100px;
|
|
326
326
|
flex-shrink: 0;
|
|
327
327
|
}
|
|
328
|
-
.event-column[data-v-
|
|
328
|
+
.event-column[data-v-520aee85] {
|
|
329
329
|
flex-grow: 1;
|
|
330
330
|
}
|
|
331
|
-
.agenda-content[data-v-
|
|
331
|
+
.agenda-content[data-v-520aee85] {
|
|
332
332
|
flex-grow: 1;
|
|
333
333
|
overflow-y: auto;
|
|
334
334
|
padding: 1rem;
|
|
335
335
|
}
|
|
336
|
-
.event[data-v-
|
|
336
|
+
.event[data-v-520aee85] {
|
|
337
337
|
margin-bottom: 1rem;
|
|
338
338
|
border-radius: 4px;
|
|
339
339
|
overflow: hidden;
|
|
340
340
|
cursor: pointer;
|
|
341
341
|
transition: all 0.2s ease;
|
|
342
342
|
}
|
|
343
|
-
.event[data-v-
|
|
343
|
+
.event[data-v-520aee85]:hover {
|
|
344
344
|
transform: scale(1.01);
|
|
345
345
|
}
|
|
346
|
-
.event-content[data-v-
|
|
346
|
+
.event-content[data-v-520aee85] {
|
|
347
347
|
display: flex;
|
|
348
348
|
height: 100%;
|
|
349
349
|
color: white;
|
|
350
350
|
}
|
|
351
|
-
.event-time[data-v-
|
|
351
|
+
.event-time[data-v-520aee85] {
|
|
352
352
|
width: 100px;
|
|
353
353
|
flex-shrink: 0;
|
|
354
354
|
padding: 0.5rem;
|
|
@@ -356,107 +356,107 @@ display: block;
|
|
|
356
356
|
align-items: center;
|
|
357
357
|
font-size: 0.9rem;
|
|
358
358
|
}
|
|
359
|
-
.event-details[data-v-
|
|
359
|
+
.event-details[data-v-520aee85] {
|
|
360
360
|
flex-grow: 1;
|
|
361
361
|
padding: 0.5rem;
|
|
362
362
|
border-left: 1px solid rgba(255, 255, 255, 0.2);
|
|
363
363
|
}
|
|
364
|
-
.event-title[data-v-
|
|
364
|
+
.event-title[data-v-520aee85] {
|
|
365
365
|
font-size: 1rem;
|
|
366
366
|
margin-bottom: 0.25rem;
|
|
367
367
|
}
|
|
368
|
-
.event-day[data-v-
|
|
368
|
+
.event-day[data-v-520aee85] {
|
|
369
369
|
font-size: 0.8rem;
|
|
370
370
|
opacity: 0.8;
|
|
371
371
|
}
|
|
372
|
-
.event-day.today[data-v-
|
|
372
|
+
.event-day.today[data-v-520aee85] {
|
|
373
373
|
color: var(--bgl-primary);
|
|
374
374
|
opacity: 1;
|
|
375
375
|
}
|
|
376
376
|
@media (max-width: 768px) {
|
|
377
|
-
.agenda-header[data-v-
|
|
377
|
+
.agenda-header[data-v-520aee85] {
|
|
378
378
|
padding: 0.5rem;
|
|
379
379
|
}
|
|
380
|
-
.time-column[data-v-
|
|
380
|
+
.time-column[data-v-520aee85] {
|
|
381
381
|
width: 80px;
|
|
382
382
|
}
|
|
383
|
-
.event-content[data-v-
|
|
383
|
+
.event-content[data-v-520aee85] {
|
|
384
384
|
font-size: 0.9rem;
|
|
385
385
|
}
|
|
386
|
-
.event-time[data-v-
|
|
386
|
+
.event-time[data-v-520aee85] {
|
|
387
387
|
width: 80px;
|
|
388
388
|
font-size: 0.8rem;
|
|
389
389
|
}
|
|
390
|
-
.event-title[data-v-
|
|
390
|
+
.event-title[data-v-520aee85] {
|
|
391
391
|
font-size: 0.9rem;
|
|
392
392
|
}
|
|
393
|
-
.event-day[data-v-
|
|
393
|
+
.event-day[data-v-520aee85] {
|
|
394
394
|
font-size: 0.7rem;
|
|
395
395
|
}
|
|
396
396
|
}
|
|
397
397
|
|
|
398
|
-
.dayGrid[data-v-
|
|
398
|
+
.dayGrid[data-v-bc647d79]{
|
|
399
399
|
display: grid;
|
|
400
400
|
grid-template-columns: 5rem 1fr;
|
|
401
401
|
}
|
|
402
|
-
.time-column[data-v-
|
|
402
|
+
.time-column[data-v-bc647d79] {
|
|
403
403
|
width: 80px;
|
|
404
404
|
flex-shrink: 0;
|
|
405
405
|
}
|
|
406
|
-
.events-column[data-v-
|
|
406
|
+
.events-column[data-v-bc647d79] {
|
|
407
407
|
flex-grow: 1;
|
|
408
408
|
position: relative;
|
|
409
409
|
border-inline-start: 1px solid var(--border-color);
|
|
410
410
|
}
|
|
411
|
-
.date-header[data-v-
|
|
411
|
+
.date-header[data-v-bc647d79] {
|
|
412
412
|
padding: 0.5rem;
|
|
413
413
|
text-align: center;
|
|
414
414
|
}
|
|
415
|
-
.day-header .events-column[data-v-
|
|
415
|
+
.day-header .events-column[data-v-bc647d79] {
|
|
416
416
|
border-inline-start: 1px solid transparent;
|
|
417
417
|
}
|
|
418
|
-
.time-slot[data-v-
|
|
418
|
+
.time-slot[data-v-bc647d79] {
|
|
419
419
|
height: 30px;
|
|
420
420
|
display: flex;
|
|
421
421
|
align-items: center;
|
|
422
422
|
justify-content: center;
|
|
423
423
|
}
|
|
424
|
-
.time-slots[data-v-
|
|
424
|
+
.time-slots[data-v-bc647d79] {
|
|
425
425
|
flex-grow: 1;
|
|
426
426
|
display: flex;
|
|
427
427
|
overflow: auto;
|
|
428
428
|
position: relative;
|
|
429
429
|
}
|
|
430
|
-
.event[data-v-
|
|
430
|
+
.event[data-v-bc647d79] {
|
|
431
431
|
left: 10px;
|
|
432
432
|
right: 10px;
|
|
433
433
|
}
|
|
434
|
-
.event[data-v-
|
|
434
|
+
.event[data-v-bc647d79]:hover {
|
|
435
435
|
z-index: 2;
|
|
436
436
|
transform: scale(1.02);
|
|
437
437
|
}
|
|
438
|
-
.event-content[data-v-
|
|
438
|
+
.event-content[data-v-bc647d79] {
|
|
439
439
|
padding: 0.5rem;
|
|
440
440
|
color: white;
|
|
441
441
|
font-size: 0.9rem;
|
|
442
442
|
height: 100%;
|
|
443
443
|
overflow: hidden;
|
|
444
444
|
}
|
|
445
|
-
.event-title[data-v-
|
|
445
|
+
.event-title[data-v-bc647d79] {
|
|
446
446
|
white-space: nowrap;
|
|
447
447
|
overflow: hidden;
|
|
448
448
|
text-overflow: ellipsis;
|
|
449
449
|
}
|
|
450
|
-
.event-time[data-v-
|
|
450
|
+
.event-time[data-v-bc647d79] {
|
|
451
451
|
font-size: 0.8rem;
|
|
452
452
|
}
|
|
453
|
-
.drag-preview[data-v-
|
|
453
|
+
.drag-preview[data-v-bc647d79] {
|
|
454
454
|
background-color: rgba(var(--bgl-primary-rgb), 0.1);
|
|
455
455
|
}
|
|
456
|
-
.current-time-line[data-v-
|
|
456
|
+
.current-time-line[data-v-bc647d79] {
|
|
457
457
|
height: 2px;
|
|
458
458
|
}
|
|
459
|
-
.custom-popover[data-v-
|
|
459
|
+
.custom-popover[data-v-bc647d79] {
|
|
460
460
|
position: fixed;
|
|
461
461
|
z-index: 1000;
|
|
462
462
|
min-width: 250px;
|
|
@@ -464,10 +464,10 @@ display: block;
|
|
|
464
464
|
background-color: white;
|
|
465
465
|
border-radius: 4px;
|
|
466
466
|
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
|
|
467
|
-
animation: fadeIn-
|
|
467
|
+
animation: fadeIn-bc647d79 0.2s ease;
|
|
468
468
|
transform-origin: center left;
|
|
469
469
|
}
|
|
470
|
-
@keyframes fadeIn-
|
|
470
|
+
@keyframes fadeIn-bc647d79 {
|
|
471
471
|
from {
|
|
472
472
|
opacity: 0;
|
|
473
473
|
transform: scale(0.95);
|
|
@@ -478,23 +478,23 @@ to {
|
|
|
478
478
|
}
|
|
479
479
|
}
|
|
480
480
|
|
|
481
|
-
.month-view[data-v-
|
|
481
|
+
.month-view[data-v-eeb8abde] {
|
|
482
482
|
display: flex;
|
|
483
483
|
flex-direction: column;
|
|
484
484
|
height: 100%;
|
|
485
485
|
overflow: hidden;
|
|
486
486
|
}
|
|
487
|
-
.month-header[data-v-
|
|
487
|
+
.month-header[data-v-eeb8abde] {
|
|
488
488
|
display: grid;
|
|
489
489
|
grid-template-columns: repeat(7, 1fr);
|
|
490
490
|
border-bottom: 1px solid var(--border-color);
|
|
491
491
|
}
|
|
492
|
-
.weekday[data-v-
|
|
492
|
+
.weekday[data-v-eeb8abde] {
|
|
493
493
|
padding: 0.5rem;
|
|
494
494
|
text-align: center;
|
|
495
495
|
color: var(--text-muted);
|
|
496
496
|
}
|
|
497
|
-
.month-grid[data-v-
|
|
497
|
+
.month-grid[data-v-eeb8abde] {
|
|
498
498
|
display: grid;
|
|
499
499
|
grid-template-columns: repeat(7, 1fr);
|
|
500
500
|
grid-template-rows: repeat(6, 1fr);
|
|
@@ -502,7 +502,7 @@ to {
|
|
|
502
502
|
overflow: auto;
|
|
503
503
|
border-inline-end: 1px solid var(--border-color);
|
|
504
504
|
}
|
|
505
|
-
.day-cell[data-v-
|
|
505
|
+
.day-cell[data-v-eeb8abde] {
|
|
506
506
|
border-inline-start: 1px solid var(--border-color);
|
|
507
507
|
border-bottom: 1px solid var(--border-color);
|
|
508
508
|
padding: 0.5rem;
|
|
@@ -510,24 +510,24 @@ to {
|
|
|
510
510
|
display: flex;
|
|
511
511
|
flex-direction: column;
|
|
512
512
|
}
|
|
513
|
-
.day-number[data-v-
|
|
513
|
+
.day-number[data-v-eeb8abde] {
|
|
514
514
|
margin-bottom: 0.5rem;
|
|
515
515
|
}
|
|
516
|
-
.other-month[data-v-
|
|
516
|
+
.other-month[data-v-eeb8abde] {
|
|
517
517
|
background-color: var(--bgl-gray-light);
|
|
518
518
|
color: var(--bgl-gray);
|
|
519
519
|
}
|
|
520
|
-
.today[data-v-
|
|
520
|
+
.today[data-v-eeb8abde] {
|
|
521
521
|
background-color: var(--bgl-primary-light);
|
|
522
522
|
}
|
|
523
|
-
.today .day-number[data-v-
|
|
523
|
+
.today .day-number[data-v-eeb8abde] {
|
|
524
524
|
color: var(--bgl-primary);
|
|
525
525
|
}
|
|
526
|
-
.day-events[data-v-
|
|
526
|
+
.day-events[data-v-eeb8abde] {
|
|
527
527
|
flex-grow: 1;
|
|
528
528
|
overflow-y: auto;
|
|
529
529
|
}
|
|
530
|
-
.event-item[data-v-
|
|
530
|
+
.event-item[data-v-eeb8abde] {
|
|
531
531
|
margin-bottom: 0.25rem;
|
|
532
532
|
padding: 0.25rem;
|
|
533
533
|
border-radius: 4px;
|
|
@@ -536,49 +536,35 @@ to {
|
|
|
536
536
|
cursor: pointer;
|
|
537
537
|
transition: all 0.2s ease;
|
|
538
538
|
}
|
|
539
|
-
.event-title[data-v-
|
|
539
|
+
.event-title[data-v-eeb8abde] {
|
|
540
540
|
font-weight: 500;
|
|
541
541
|
white-space: nowrap;
|
|
542
542
|
overflow: hidden;
|
|
543
543
|
text-overflow: ellipsis;
|
|
544
544
|
}
|
|
545
|
-
.event-time[data-v-
|
|
545
|
+
.event-time[data-v-eeb8abde] {
|
|
546
546
|
font-size: 0.7rem;
|
|
547
547
|
opacity: 0.8;
|
|
548
548
|
}
|
|
549
|
-
.event-dot[data-v-
|
|
549
|
+
.event-dot[data-v-eeb8abde] {
|
|
550
550
|
width: 6px;
|
|
551
551
|
height: 6px;
|
|
552
552
|
background-color: var(--bgl-primary);
|
|
553
553
|
border-radius: 50%;
|
|
554
554
|
margin: 0.25rem auto;
|
|
555
555
|
}
|
|
556
|
-
|
|
557
|
-
.day-cell[data-v-505b680c] {
|
|
558
|
-
min-height: 60px;
|
|
559
|
-
padding: 0.25rem;
|
|
560
|
-
}
|
|
561
|
-
.day-number[data-v-505b680c] {
|
|
562
|
-
font-size: 0.8rem;
|
|
563
|
-
margin-bottom: 0.25rem;
|
|
564
|
-
}
|
|
565
|
-
.weekday[data-v-505b680c] {
|
|
566
|
-
font-size: 0.8rem;
|
|
567
|
-
padding: 0.25rem;
|
|
568
|
-
}
|
|
569
|
-
}
|
|
570
|
-
.custom-popover[data-v-505b680c] {
|
|
556
|
+
.custom-popover[data-v-eeb8abde] {
|
|
571
557
|
position: fixed;
|
|
572
558
|
z-index: 1000;
|
|
573
559
|
min-width: 250px;
|
|
574
560
|
max-width: 350px;
|
|
575
561
|
background-color: white;
|
|
576
|
-
border-radius:
|
|
562
|
+
border-radius: var(--btn-border-radius);
|
|
577
563
|
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
|
|
578
|
-
animation: fadeIn-
|
|
564
|
+
animation: fadeIn-eeb8abde 0.2s ease;
|
|
579
565
|
transform-origin: center left;
|
|
580
566
|
}
|
|
581
|
-
@keyframes fadeIn-
|
|
567
|
+
@keyframes fadeIn-eeb8abde {
|
|
582
568
|
from {
|
|
583
569
|
opacity: 0;
|
|
584
570
|
transform: scale(0.95);
|
|
@@ -588,50 +574,64 @@ to {
|
|
|
588
574
|
transform: scale(1);
|
|
589
575
|
}
|
|
590
576
|
}
|
|
577
|
+
@media (max-width: 768px) {
|
|
578
|
+
.day-cell[data-v-eeb8abde] {
|
|
579
|
+
min-height: 60px;
|
|
580
|
+
padding: 0.25rem;
|
|
581
|
+
}
|
|
582
|
+
.day-number[data-v-eeb8abde] {
|
|
583
|
+
font-size: 0.8rem;
|
|
584
|
+
margin-bottom: 0.25rem;
|
|
585
|
+
}
|
|
586
|
+
.weekday[data-v-eeb8abde] {
|
|
587
|
+
font-size: 0.8rem;
|
|
588
|
+
padding: 0.25rem;
|
|
589
|
+
}
|
|
590
|
+
}
|
|
591
591
|
|
|
592
|
-
.weekGrid[data-v-
|
|
592
|
+
.weekGrid[data-v-b897fbe8]{
|
|
593
593
|
display: grid;
|
|
594
594
|
grid-template-columns: 5rem repeat(7, 1fr);
|
|
595
595
|
}
|
|
596
|
-
.days-column[data-v-
|
|
596
|
+
.days-column[data-v-b897fbe8] {
|
|
597
597
|
flex-grow: 1;
|
|
598
598
|
display: flex;
|
|
599
599
|
}
|
|
600
|
-
.time-slot[data-v-
|
|
600
|
+
.time-slot[data-v-b897fbe8] {
|
|
601
601
|
height: 30px;
|
|
602
602
|
display: flex;
|
|
603
603
|
align-items: center;
|
|
604
604
|
justify-content: center;
|
|
605
605
|
color: var(--text-muted);
|
|
606
606
|
}
|
|
607
|
-
.time-slots[data-v-
|
|
607
|
+
.time-slots[data-v-b897fbe8] {
|
|
608
608
|
flex-grow: 1;
|
|
609
609
|
display: flex;
|
|
610
610
|
overflow: auto;
|
|
611
611
|
position: relative;
|
|
612
612
|
}
|
|
613
|
-
.day-column[data-v-
|
|
613
|
+
.day-column[data-v-b897fbe8] {
|
|
614
614
|
flex: 1;
|
|
615
615
|
}
|
|
616
|
-
.event[data-v-
|
|
616
|
+
.event[data-v-b897fbe8] {
|
|
617
617
|
margin-right: 2px;
|
|
618
618
|
}
|
|
619
|
-
.event[data-v-
|
|
619
|
+
.event[data-v-b897fbe8]:hover {
|
|
620
620
|
z-index: 1;
|
|
621
621
|
}
|
|
622
|
-
.drag-preview[data-v-
|
|
622
|
+
.drag-preview[data-v-b897fbe8] {
|
|
623
623
|
border: 2px solid var(--bgl-primary);
|
|
624
624
|
}
|
|
625
|
-
.current-time-line[data-v-
|
|
625
|
+
.current-time-line[data-v-b897fbe8] {
|
|
626
626
|
height: 2px;
|
|
627
627
|
}
|
|
628
|
-
.custom-popover[data-v-
|
|
628
|
+
.custom-popover[data-v-b897fbe8] {
|
|
629
629
|
min-width: 250px;
|
|
630
630
|
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
|
|
631
|
-
animation: fadeIn-
|
|
631
|
+
animation: fadeIn-b897fbe8 0.2s ease;
|
|
632
632
|
transform-origin: center left;
|
|
633
633
|
}
|
|
634
|
-
@keyframes fadeIn-
|
|
634
|
+
@keyframes fadeIn-b897fbe8 {
|
|
635
635
|
from {
|
|
636
636
|
opacity: 0;
|
|
637
637
|
transform: scale(0.95);
|
|
@@ -644,7 +644,7 @@ to {
|
|
|
644
644
|
@media screen and (max-width: 910px) {
|
|
645
645
|
}
|
|
646
646
|
|
|
647
|
-
.calendar[data-v-
|
|
647
|
+
.calendar[data-v-36ea5622] {
|
|
648
648
|
display: flex;
|
|
649
649
|
flex-direction: column;
|
|
650
650
|
height: 100%;
|
|
@@ -1462,9 +1462,18 @@ pre code.hljs{
|
|
|
1462
1462
|
opacity: 0.4;
|
|
1463
1463
|
}
|
|
1464
1464
|
|
|
1465
|
-
.date-picker-container
|
|
1465
|
+
.date-picker-container {
|
|
1466
1466
|
width: 100%;
|
|
1467
1467
|
}
|
|
1468
|
+
.date-picker-container .date-input{
|
|
1469
|
+
--input-bg: transparent;
|
|
1470
|
+
--input-font-size: 12px;
|
|
1471
|
+
opacity: 0.6;
|
|
1472
|
+
--input-height: 20px;
|
|
1473
|
+
}
|
|
1474
|
+
.date-picker-container .date-input .bagel-input input{
|
|
1475
|
+
padding: 0 !important;
|
|
1476
|
+
}
|
|
1468
1477
|
|
|
1469
1478
|
.fileUploadWrap[data-v-50fd0597] {
|
|
1470
1479
|
outline: 1px solid var(--border-color);
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { DateLike } from '@vueuse/core';
|
|
1
2
|
import { AvailableTimeLanguages, DateTimeAcceptedFormats } from '../../types/timeAgoT';
|
|
2
3
|
interface TimeDeltaOptions {
|
|
3
4
|
day?: number;
|
|
@@ -16,8 +17,8 @@ export declare function timeAgo(date: string | Date, lang?: AvailableTimeLanguag
|
|
|
16
17
|
* @param timeZone The timezone to use (e.g., 'UTC', 'America/New_York')
|
|
17
18
|
* @returns Date parts with timezone adjustment applied
|
|
18
19
|
*/
|
|
19
|
-
export declare function handleTimezone(date: Date,
|
|
20
|
-
export declare function getDatePartsMap(date: Date, locale: Intl.LocalesArgument,
|
|
20
|
+
export declare function handleTimezone(date: Date, locale: Intl.LocalesArgument, intFmtOpt: Intl.DateTimeFormatOptions): Date;
|
|
21
|
+
export declare function getDatePartsMap(date: Date, locale: Intl.LocalesArgument, intFmtOpt?: Intl.DateTimeFormatOptions): {
|
|
21
22
|
AmPm: string;
|
|
22
23
|
DD: string;
|
|
23
24
|
DDD: string;
|
|
@@ -32,16 +33,21 @@ export declare function getDatePartsMap(date: Date, locale: Intl.LocalesArgument
|
|
|
32
33
|
YY: string;
|
|
33
34
|
YYYY: string;
|
|
34
35
|
};
|
|
35
|
-
export
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
date?: FormatDateFnParams[0];
|
|
40
|
-
format?: FormatDateFnParams[1];
|
|
41
|
-
locale?: FormatDateFnParams[2];
|
|
42
|
-
timeZone?: FormatDateFnParams[3];
|
|
36
|
+
export interface FormatDateOptions extends Partial<Pick<Intl.DateTimeFormatOptions, 'hour12'>> {
|
|
37
|
+
fmt?: DateTimeAcceptedFormats;
|
|
38
|
+
locale?: Intl.LocalesArgument;
|
|
39
|
+
tz?: string;
|
|
43
40
|
}
|
|
44
|
-
|
|
45
|
-
|
|
41
|
+
/**
|
|
42
|
+
* Formats a date based on the provided format string, locale, and timezone.
|
|
43
|
+
* @param date The date to format (string or Date object).
|
|
44
|
+
* @param opts Options for formatting the date.
|
|
45
|
+
* @param opts.fmt The format string (default is 'DD.MM.YY').
|
|
46
|
+
* @param opts.locale The locale to use for formatting (default is browser's locale).
|
|
47
|
+
* @param opts.tz The timezone to use for formatting (default is local timezone).
|
|
48
|
+
* @returns Formatted date string.
|
|
49
|
+
*/
|
|
50
|
+
export declare function formatDate(date?: DateLike, opts?: FormatDateOptions): string;
|
|
51
|
+
export declare const fmtDate: typeof formatDate;
|
|
46
52
|
export {};
|
|
47
53
|
//# sourceMappingURL=dateUtils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dateUtils.d.ts","sourceRoot":"","sources":["../../../src/utils/calendar/dateUtils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,uBAAuB,EAAkC,MAAM,sBAAsB,CAAA;AAE3H,UAAU,gBAAgB;IACzB,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,MAAM,CAAA;CACb;AAED,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,EAAE,OAAO,EAAE,gBAAgB,QAyBvE;AAqDD,wBAAgB,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,EAAE,IAAI,GAAE,sBAA6B,UAsD/E;AASD;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,IAAI,EAAE,
|
|
1
|
+
{"version":3,"file":"dateUtils.d.ts","sourceRoot":"","sources":["../../../src/utils/calendar/dateUtils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,KAAK,EAAE,sBAAsB,EAAE,uBAAuB,EAAkC,MAAM,sBAAsB,CAAA;AAE3H,UAAU,gBAAgB;IACzB,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,MAAM,CAAA;CACb;AAED,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,EAAE,OAAO,EAAE,gBAAgB,QAyBvE;AAqDD,wBAAgB,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,EAAE,IAAI,GAAE,sBAA6B,UAsD/E;AASD;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE,SAAS,EAAE,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAuCpH;AAED,wBAAgB,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE,SAAS,CAAC,EAAE,IAAI,CAAC,qBAAqB;;;;;;;;;;;;;;EAqB/G;AAcD,MAAM,WAAW,iBAAkB,SAAQ,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,QAAQ,CAAC,CAAC;IAC7F,GAAG,CAAC,EAAE,uBAAuB,CAAA;IAC7B,MAAM,CAAC,EAAE,IAAI,CAAC,eAAe,CAAA;IAC7B,EAAE,CAAC,EAAE,MAAM,CAAA;CACX;AACD;;;;;;;;GAQG;AACH,wBAAgB,UAAU,CACzB,IAAI,CAAC,EAAE,QAAQ,EACf,IAAI,GAAE,iBAAsB,GAC1B,MAAM,CAuER;AACD,eAAO,MAAM,OAAO,mBAAa,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
<script setup lang="ts">
|
|
2
2
|
import type { Component } from 'vue'
|
|
3
3
|
import type { CalendarEvent, CalendarView, WeekStart } from './CalendarTypes'
|
|
4
|
-
import { timeDelta, Btn,
|
|
4
|
+
import { timeDelta, Btn, ListItem, Dropdown, fmtDate } from '@bagelink/vue'
|
|
5
5
|
import { ref, computed } from 'vue'
|
|
6
6
|
import AgendaView from './views/AgendaView.vue'
|
|
7
7
|
import DayView from './views/DayView.vue'
|
|
@@ -9,7 +9,7 @@ import MonthView from './views/MonthView.vue'
|
|
|
9
9
|
import WeekView from './views/WeekView.vue'
|
|
10
10
|
|
|
11
11
|
interface CalendarProps {
|
|
12
|
-
events
|
|
12
|
+
events?: CalendarEvent[]
|
|
13
13
|
startDate?: Date
|
|
14
14
|
view?: CalendarView
|
|
15
15
|
weekStart?: WeekStart
|
|
@@ -18,7 +18,8 @@ interface CalendarProps {
|
|
|
18
18
|
const props = withDefaults(defineProps<CalendarProps>(), {
|
|
19
19
|
startDate: () => new Date(),
|
|
20
20
|
view: 'Week',
|
|
21
|
-
weekStart: 'Sunday'
|
|
21
|
+
weekStart: 'Sunday',
|
|
22
|
+
events: () => []
|
|
22
23
|
})
|
|
23
24
|
|
|
24
25
|
const emit = defineEmits<{
|
|
@@ -97,8 +98,8 @@ defineExpose({ visibleDateRange })
|
|
|
97
98
|
<div class="calendar">
|
|
98
99
|
<div class="flex m_block m_pb-1">
|
|
99
100
|
<h3 class="txt-light my-0">
|
|
100
|
-
<b>{{
|
|
101
|
-
{{
|
|
101
|
+
<b>{{ fmtDate(currentDate, { fmt: 'MMMM' }) }}</b>
|
|
102
|
+
{{ fmtDate(currentDate, { fmt: 'YYYY' }) }}
|
|
102
103
|
</h3>
|
|
103
104
|
<div class="ms-auto flex gap-025">
|
|
104
105
|
<Dropdown thin :value="currentView" iconEnd="keyboard_arrow_down" color="gray">
|
|
@@ -141,7 +141,7 @@ onUnmounted(() => {
|
|
|
141
141
|
>
|
|
142
142
|
<div class="event-content">
|
|
143
143
|
<div class="event-time">
|
|
144
|
-
{{ formatDate(event.start_time, 'HH:mm') }}
|
|
144
|
+
{{ formatDate(event.start_time, { fmt: 'HH:mm' }) }}
|
|
145
145
|
</div>
|
|
146
146
|
<div class="event-details">
|
|
147
147
|
<div class="event-title">
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
<script setup lang="ts">
|
|
2
|
+
import type { SetupContext } from 'vue'
|
|
2
3
|
import type { CalendarEvent } from '../CalendarTypes'
|
|
3
4
|
import type { PopoverState } from '../utils'
|
|
4
5
|
import { formatDate } from '@bagelink/vue'
|
|
@@ -18,7 +19,7 @@ const emit = defineEmits<{
|
|
|
18
19
|
(e: 'eventCreate', event: { start_time: Date, end_time: Date }): void
|
|
19
20
|
}>()
|
|
20
21
|
|
|
21
|
-
const slots = useSlots()
|
|
22
|
+
const slots: SetupContext['slots'] = useSlots()
|
|
22
23
|
|
|
23
24
|
// Configuration constants
|
|
24
25
|
const slotHeight = 60
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
<script setup lang="ts">
|
|
2
|
+
import type { SetupContext } from 'vue'
|
|
2
3
|
import type { CalendarEvent } from '../CalendarTypes'
|
|
3
4
|
import type { PopoverState } from '../utils'
|
|
4
|
-
import { Card,
|
|
5
|
+
import { Card, fmtDate } from '@bagelink/vue'
|
|
5
6
|
import { ref, computed, useSlots } from 'vue'
|
|
6
7
|
import {
|
|
7
8
|
openPopover as openPopoverUtil,
|
|
@@ -24,7 +25,7 @@ const emit = defineEmits<{
|
|
|
24
25
|
(e: 'eventClick', event: CalendarEvent): void
|
|
25
26
|
}>()
|
|
26
27
|
|
|
27
|
-
const slots = useSlots()
|
|
28
|
+
const slots: SetupContext['slots'] = useSlots()
|
|
28
29
|
|
|
29
30
|
// Responsive state
|
|
30
31
|
const isMobile = computed(() => window.innerWidth < 768)
|
|
@@ -136,7 +137,7 @@ function closePopover() {
|
|
|
136
137
|
}"
|
|
137
138
|
>
|
|
138
139
|
<div class="day-number">
|
|
139
|
-
{{
|
|
140
|
+
{{ fmtDate(day.date, { fmt: 'DD' }) }}
|
|
140
141
|
</div>
|
|
141
142
|
<div class="day-events">
|
|
142
143
|
<template v-if="isMobile">
|
|
@@ -154,7 +155,7 @@ function closePopover() {
|
|
|
154
155
|
{{ event.title }}
|
|
155
156
|
</div>
|
|
156
157
|
<div class="event-time">
|
|
157
|
-
{{
|
|
158
|
+
{{ fmtDate(event.start_time, { fmt: 'HH:mm' }) }}
|
|
158
159
|
</div>
|
|
159
160
|
</div>
|
|
160
161
|
</template>
|
|
@@ -271,30 +272,13 @@ function closePopover() {
|
|
|
271
272
|
margin: 0.25rem auto;
|
|
272
273
|
}
|
|
273
274
|
|
|
274
|
-
@media (max-width: 768px) {
|
|
275
|
-
.day-cell {
|
|
276
|
-
min-height: 60px;
|
|
277
|
-
padding: 0.25rem;
|
|
278
|
-
}
|
|
279
|
-
|
|
280
|
-
.day-number {
|
|
281
|
-
font-size: 0.8rem;
|
|
282
|
-
margin-bottom: 0.25rem;
|
|
283
|
-
}
|
|
284
|
-
|
|
285
|
-
.weekday {
|
|
286
|
-
font-size: 0.8rem;
|
|
287
|
-
padding: 0.25rem;
|
|
288
|
-
}
|
|
289
|
-
}
|
|
290
|
-
|
|
291
275
|
.custom-popover {
|
|
292
276
|
position: fixed;
|
|
293
277
|
z-index: 1000;
|
|
294
278
|
min-width: 250px;
|
|
295
279
|
max-width: 350px;
|
|
296
280
|
background-color: white;
|
|
297
|
-
border-radius:
|
|
281
|
+
border-radius: var(--btn-border-radius);
|
|
298
282
|
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
|
|
299
283
|
animation: fadeIn 0.2s ease;
|
|
300
284
|
transform-origin: center left;
|
|
@@ -310,4 +294,21 @@ function closePopover() {
|
|
|
310
294
|
transform: scale(1);
|
|
311
295
|
}
|
|
312
296
|
}
|
|
297
|
+
|
|
298
|
+
@media (max-width: 768px) {
|
|
299
|
+
.day-cell {
|
|
300
|
+
min-height: 60px;
|
|
301
|
+
padding: 0.25rem;
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
.day-number {
|
|
305
|
+
font-size: 0.8rem;
|
|
306
|
+
margin-bottom: 0.25rem;
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
.weekday {
|
|
310
|
+
font-size: 0.8rem;
|
|
311
|
+
padding: 0.25rem;
|
|
312
|
+
}
|
|
313
|
+
}
|
|
313
314
|
</style>
|