UNPKG

truly-ui

Version:

Web Components for Desktop Applications.

345 lines 84 kB
import { Component, Input, ChangeDetectionStrategy, Output, EventEmitter, ViewChildren } from '@angular/core'; import { WorkScaleType } from '../../types/work-scale.type'; import { Subscription } from 'rxjs'; import { ScheduleI18n } from '../../i18n/schedule-i18n'; import * as i0 from "@angular/core"; import * as i1 from "../../services/generate-events.service"; import * as i2 from "../../services/event.service"; import * as i3 from "../../services/work-scale.service"; import * as i4 from "@angular/common"; import * as i5 from "../../../tooltip/directives/tooltip.directive"; import * as i6 from "../../../icons/icons"; export class WeekComponent { constructor(changeDetectionRef, generateEvents, eventService, workScaleService) { this.changeDetectionRef = changeDetectionRef; this.generateEvents = generateEvents; this.eventService = eventService; this.workScaleService = workScaleService; this.currentDate = []; this.showNowIndicator = false; this.texts = ScheduleI18n; this.onRowDbClick = new EventEmitter(); this.onRowClick = new EventEmitter(); this.onEventDbClick = new EventEmitter(); this.onEventClick = new EventEmitter(); this.onEventMouseover = new EventEmitter(); this.onEventMouseout = new EventEmitter(); this.onEventContextmenu = new EventEmitter(); this.currentTime = new Date(); this.indexRowSelected = null; this.weekEvents = []; this.eventsWithPositions = []; this.subscriptions = new Subscription(); this.subscriptions.add(this.workScaleService.updateScale.subscribe((timesCollection) => { this.timesCollection = timesCollection; this.changeDetectionRef.detectChanges(); this.indexRowSelected = null; })); this.subscriptions.add(this.eventService.updateEvents.subscribe((event) => { this.generateEventsPositions(event); this.inicializeNowIndicator(); this.changeDetectionRef.detectChanges(); this.indexRowSelected = null; })); } ngOnInit() { this.initializeCurrentDate(); } initializeCurrentDate() { const currentDate = new Date(); // Obter o dia da semana (0 - domingo, 1 - segunda-feira, ..., 6 - sábado) const currentDay = currentDate.getDay(); // Calcular os dias que faltam para o próximo domingo const daysRemaining = 7 - currentDay; // Preencher o array currentDate com os dias que faltam for (let i = 0; i < daysRemaining; i++) { const date = new Date(currentDate); date.setDate(currentDate.getDate() + i); this.currentDate.push(date); } } ngAfterViewInit() { } ngOnChanges(changes) { if (changes['currentDate'] !== undefined) { this.workScaleService.currentDate = changes['currentDate'].currentValue; this.indexRowSelected = null; this.eventService.getEventsOfDay(); } if (changes['workScale'] !== undefined) { this.indexRowSelected = null; this.workScaleService.reload(changes['workScale'].currentValue); } if (changes['events'] !== undefined) { this.createWorkScaleByEvents(changes['events'].currentValue); this.indexRowSelected = null; this.eventService.loadEvents(changes['events'].currentValue); this.eventService.getEventsOfDay(); const currentDate = this.workScaleService.currentDate; // Obter a data de início e fim da semana atual const startDate = new Date(currentDate); startDate.setDate(startDate.getDate() - startDate.getDay()); // Definir o dia da semana para o domingo startDate.setHours(0, 0, 0, 0); // Definir as horas, minutos, segundos e milissegundos para zero const endDate = new Date(startDate); endDate.setDate(startDate.getDate() + 6); // Definir o dia da semana para o sábado endDate.setHours(23, 59, 59, 999); // Definir as horas, minutos, segundos e milissegundos para o final do dia // Filtrar os eventos dentro do intervalo de datas const events = changes['events'].currentValue.filter((event) => event.date.start >= startDate && event.date.start <= endDate); // Agrupar os eventos por dia da semana const groupedEvents = events.reduce((result, event) => { const start = event.date.start; if (start instanceof Date) { const day = start.getDay(); const dayOfWeek = ['Domingo', 'Segunda', 'Terça', 'Quarta', 'Quinta', 'Sexta', 'Sábado'][day]; if (!result[dayOfWeek]) { result[dayOfWeek] = { day: dayOfWeek, events: [] }; } result[dayOfWeek].events.push(event); } return result; }, {}); // Converter o objeto em um array de objetos {day: string, events: ScheduleDataSource[]} this.weekEvents = Object.keys(groupedEvents).map((dayOfWeek) => ({ day: dayOfWeek, events: groupedEvents[dayOfWeek] })); // Calcular o intervalo entre os dias da semana de cada mês const monthStart = new Date(startDate.getFullYear(), startDate.getMonth(), 1); const monthEnd = new Date(startDate.getFullYear(), startDate.getMonth() + 1, 0); this.monthInterval = `${monthStart.toLocaleDateString()} - ${monthEnd.toLocaleDateString()}`; this.changeDetectionRef.detectChanges(); } } rowDbClick(time, index, periodIndex) { const workScaleInterval = this.workScaleService.workScale[periodIndex].interval; const minutesToStart = index > 0 ? (workScaleInterval / this.slotSettings.slotCount) * (index) : 0; const minutesToEnd = (workScaleInterval / this.slotSettings.slotCount) * (index + 1); const startDate = new Date(time); startDate.setMinutes(startDate.getMinutes() + minutesToStart); const endDate = new Date(time); endDate.setMinutes(endDate.getMinutes() + minutesToEnd); const startOfWeek = startDate.getDate() - startDate.getDay() + 1; const endOfWeek = startOfWeek + 6; const startOfWeekDate = new Date(startDate.setDate(startOfWeek)); const endOfWeekDate = new Date(startDate.setDate(endOfWeek)); this.onRowDbClick.emit({ start: startOfWeekDate, end: endOfWeekDate, }); } rowClick(time, index, periodIndex, scheduleRow) { const workScaleInterval = this.workScaleService.workScale[periodIndex].interval; const minutesToStart = index > 0 ? (workScaleInterval / this.slotSettings.slotCount) * (index) : 0; const minutesToEnd = (workScaleInterval / this.slotSettings.slotCount) * (index + 1); this.indexRowSelected = scheduleRow.getAttribute('data-row-index'); const startDate = new Date(time); startDate.setMinutes(startDate.getMinutes() + minutesToStart); const endDate = new Date(time); endDate.setMinutes(endDate.getMinutes() + minutesToEnd); const startOfWeek = startDate.getDate() - startDate.getDay() + 1; const endOfWeek = startOfWeek + 6; const startOfWeekDate = new Date(startDate.setDate(startOfWeek)); const endOfWeekDate = new Date(startDate.setDate(endOfWeek)); this.onRowClick.emit({ start: startOfWeekDate, end: endOfWeekDate, }); } inicializeNowIndicator() { this.nowIndicatorPositionTop = this.showNowIndicator ? this.generateEvents.convertMillisecondsToPixel() : -1000; this.changeDetectionRef.detectChanges(); } generateEventsPositions(events) { if (events !== undefined) { this.generateEvents.initializeArray(this.workScaleService.workScaleInMileseconds, this.scheduleSlats); this.eventsWithPositions = this.generateEvents.with(events); } } createWorkScaleByEvents(events) { const workScale = [ // configure os valores desejados aqui new WorkScaleType('08:00', '13:30', 30), new WorkScaleType('13:30', '18:00', 60), new WorkScaleType('31:00', '36:30', 30), new WorkScaleType('36:30', '43:00', 60), new WorkScaleType('55:00', '60:30', 30), new WorkScaleType('60:30', '67:00', 60), new WorkScaleType('79:00', '84:30', 30), new WorkScaleType('84:30', '91:00', 60), new WorkScaleType('103:00', '108:30', 30), new WorkScaleType('108:30', '115:00', 60), new WorkScaleType('127:00', '132:30', 30), new WorkScaleType('132:30', '139:00', 60), new WorkScaleType('151:00', '156:30', 30), new WorkScaleType('156:30', '162:00', 60) ]; if (workScale && workScale.length > 0) { const scales = workScale.filter((work) => work.expansed === undefined); for (let i = 0; i <= events.length - 1; i++) { workScale.forEach((value, workScaleIndex, array) => { const eventStartDate = new Date(events[i].date.start); eventStartDate.setSeconds(0, 0); const eventEndDate = new Date(events[i].date.end); eventEndDate.setSeconds(0, 0); const workStartDate = this.workScaleService.transformHourToMileseconds(scales[workScaleIndex].start, eventStartDate); const workEndDate = this.workScaleService.transformHourToMileseconds(scales[workScaleIndex].end, eventEndDate); if ((eventEndDate.getTime() >= workEndDate && eventStartDate.getTime() >= workEndDate) || (eventEndDate.getTime() >= workEndDate && eventStartDate.getTime() <= workEndDate)) { if (workScale.length - 1 === workScaleIndex) { scales.push({ end: this.workScaleService.transformMilesecondsToHour(eventEndDate.getTime()), start: this.workScaleService.transformMilesecondsToHour(eventStartDate.getTime()), interval: scales[workScaleIndex].interval, expansed: true, }); } } if ((eventEndDate.getTime() <= workStartDate && eventStartDate.getTime() <= workStartDate) || (eventEndDate.getTime() <= workStartDate && eventStartDate.getTime() >= workStartDate)) { if (workScaleIndex === 0) { scales.push({ end: this.workScaleService.transformMilesecondsToHour(eventEndDate.getTime()), start: this.workScaleService.transformMilesecondsToHour(eventStartDate.getTime()), interval: scales[workScaleIndex].interval, expansed: true, }); } } }); } this.workScaleService.reload(this.addMiddleScales(events, this.reduceScales(scales))); } } addMiddleScales(events, workScale) { const scales = workScale.filter(work => work); for (let workScaleIndex = 0; workScaleIndex < workScale.length - 1; workScaleIndex++) { for (let e = 0; e <= events.length - 1; e++) { const eventStartDate = new Date(events[e].date.start).setSeconds(0, 0); const eventEndDate = new Date(events[e].date.end).setSeconds(0, 0); const workStartDate = this.workScaleService.transformHourToMileseconds(workScale[workScaleIndex].end, new Date(eventStartDate)); const workEndDate = this.workScaleService.transformHourToMileseconds(workScale[workScaleIndex + 1].start, new Date(eventEndDate)); // Horario de inicio dentro do intervalo if (eventStartDate >= workStartDate && eventStartDate <= workEndDate) { scales.push({ start: workScale[workScaleIndex].end, end: workScale[workScaleIndex + 1].start, interval: workScale[workScaleIndex].interval, expansed: true, middle: true, }); break; } // Horario de fim dentro do intervalo if (eventEndDate >= workStartDate && eventEndDate <= workEndDate) { scales.push({ start: workScale[workScaleIndex].end, end: workScale[workScaleIndex + 1].start, interval: workScale[workScaleIndex].interval, expansed: true, middle: true, }); break; } } } return this.reduceScales(scales); } reduceScales(scales) { const orderedScales = this.sortScaleByStart(scales); const notExpansedScales = orderedScales.filter((scale) => !scale.expansed); const middleHourScale = orderedScales.filter((scale) => scale.middle); const beforeHourScale = this.reduceBeforeScale(orderedScales); const afterHourScale = this.reduceAfterScale(orderedScales); return this.sortScaleByStart(this.removeNextSameStartAndEndSacalesTime(this.removeSameStartAndEndSacalesTime(notExpansedScales.concat(afterHourScale).concat(middleHourScale).concat(beforeHourScale)))); } removeSameStartAndEndSacalesTime(scales) { return this.sortScaleByStart(scales).filter((value => value.start !== value.end)); } removeNextSameStartAndEndSacalesTime(scales) { return this.sortScaleByStart(scales).filter((value, index, array) => { if (array[index - 1]) { return value.start !== array[index - 1].start && value.end !== array[index - 1].end; } return true; }); } reduceBeforeScale(scales) { return scales.reduce((previous, current) => { const cStart = this.workScaleService.transformHourToMileseconds(current.start); const pStart = this.workScaleService.transformHourToMileseconds(previous.start); if (cStart < pStart) { return { ...current, start: current.start }; } const cEnd = this.workScaleService.transformHourToMileseconds(current.end); const pEnd = this.workScaleService.transformHourToMileseconds(previous.end); if (cEnd < pEnd) { return { ...current, end: current.end }; } return previous; }, { end: '23:59', start: '23:59', interval: 0, expansed: null }); } reduceAfterScale(scales) { return scales.reduce((previous, current) => { const cStart = this.workScaleService.transformHourToMileseconds(current.start); const pStart = this.workScaleService.transformHourToMileseconds(previous.start); if (cStart > pStart) { return { ...current, start: current.start }; } const cEnd = this.workScaleService.transformHourToMileseconds(current.end); const pEnd = this.workScaleService.transformHourToMileseconds(previous.end); if (cEnd > pEnd) { return { ...current, end: current.end }; } return previous; }, { end: '01:00', start: '01:00', interval: 0, expansed: null }); } sortScaleByStart(scales) { return scales.sort((scaleA, scaleB) => { return this.workScaleService.transformHourToMileseconds(scaleA.start) - this.workScaleService.transformHourToMileseconds(scaleB.start); }); } ngOnDestroy() { this.subscriptions.unsubscribe(); } } /** @nocollapse */ WeekComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WeekComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.GenerateEventsService }, { token: i2.EventService }, { token: i3.WorkScaleService }], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ WeekComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: WeekComponent, selector: "tl-week", inputs: { statusConfig: "statusConfig", typesConfig: "typesConfig", showNowIndicator: "showNowIndicator", slotSettings: "slotSettings", workScale: "workScale", slatNumberRowsAsArray: "slatNumberRowsAsArray", texts: "texts", events: "events" }, outputs: { onRowDbClick: "onRowDbClick", onRowClick: "onRowClick", onEventDbClick: "onEventDbClick", onEventClick: "onEventClick", onEventMouseover: "onEventMouseover", onEventMouseout: "onEventMouseout", onEventContextmenu: "onEventContextmenu" }, viewQueries: [{ propertyName: "scheduleSlats", predicate: ["scheduleSlats"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"ui-schedule-slats\"\n *ngFor=\"let times of timesCollection; let timesIndex = index; let lastTurn = last; let firstTurn = first;\">\n\n <!-- CREATE TIMES BOXES-->\n <div class=\"ui-schedule-times\">\n <div class=\"ui-schedule-time-row\"\n *ngFor=\"let time of times\"\n [ngClass]=\"{ firstTurn: firstTurn }\"\n [ngStyle]=\"{\n height: (slotSettings.slotCount * slotSettings.slotHight) + 'px',\n 'align-items': slotSettings.slotCount > 1 ? 'flex-start' : 'center'\n }\">\n <div class=\"ui-schedule-time-description\">\n <span class=\"ui-hour-detail\">{{time | date: 'dd/MM'}}</span><br>\n <span>{{time | date: 'HH:mm'}}</span>\n </div>\n </div>\n </div>\n\n <!-- CREATE WIDGET CONTENT-->\n <div #scheduleSlats class=\"ui-schedule-widget-content\">\n <div *ngFor=\"let time of times; let last = last; let first = first;\" class=\"ui-schedule-widget-rows\">\n <div #scheduleRow class=\"ui-schedule-row\" [attr.data-row-index]=\"time.getTime() * (index+1)\" *ngFor=\"let slot of slatNumberRowsAsArray; let index = index\"\n (click)=\"rowClick( time, index, timesIndex, scheduleRow )\"\n (dblclick)=\"rowDbClick( time, index, timesIndex )\"\n [ngStyle]=\"{ height: slotSettings.slotHight + 'px' }\"\n [ngClass]=\"{ last: last, first: first, lastTurn: lastTurn, firstTurn: firstTurn }\"\n [class.selected]=\"scheduleRow?.getAttribute('data-row-index') === indexRowSelected\">\n </div>\n </div>\n </div>\n\n</div>\n<div class=\"ui-schedule-skeleton\" >\n <div class=\"ui-schedule-grid-events\">\n <div class=\"ui-schedule-list-events\">\n\n <!-- CREATE EVENTS BOXES-->\n <div class=\"ui-schedule-event-box\" [style.borderLeftWidth]=\"event?.data?.blocked ? 0 : '5px'\"\n #elementBox\n *ngFor=\"let event of eventsWithPositions; let index = index\"\n [ngStyle]=\"{\n top: event?.positions.top + 'px',\n left: event?.positions.left + 'px',\n height: event?.positions.height + 'px',\n width: event?.positions.width + 'px'\n }\"\n [style.borderLeftColor]=\"statusConfig ? statusConfig[event?.data?.status]?.color : '#FFFFFF'\"\n [tooltip]=\"{text: statusConfig ? statusConfig[event?.data?.status]?.description : '' , placement: 'top-center'}\"\n (contextmenu)=\"onEventContextmenu.emit( { event: $event, data: event?.data, element: elementBox } ); false\"\n (click)=\"onEventClick.emit( event?.data )\"\n (dblclick)=\"onEventDbClick.emit( event?.data )\"\n (mouseover)=\"onEventMouseout.emit( event?.data )\"\n (mouseout)=\"onEventMouseout.emit( event?.data )\"\n >\n <ng-container *ngIf=\"!event?.data?.blocked\">\n <div class=\"ui-schedule-event-content\">\n <div class=\"ui-event-data\">\n <div class=\"ui-event-title\">\n <span class=\"title\">{{event?.data?.title}}</span>\n <div class=\"tags\" *ngIf=\"event?.data?.tags?.length > 0 \">\n <div class=\"tag-item\" *ngFor=\"let tag of event?.data?.tags;\" [style.backgroundColor]=\"tag.color\" >\n {{tag.title}}\n </div>\n </div>\n </div>\n <div class=\"ui-event-detail\">{{event?.data?.detail}}</div>\n </div>\n <div class=\"ui-event-note\">\n {{event?.data?.note}}\n </div>\n </div>\n <div class=\"ui-event-hour\">\n <span>{{event?.data?.date?.start | date: 'dd/yy'}} - {{event?.data?.date?.end | date: 'dd/yy'}}</span>\n <span class=\"ui-event-typeconfig-description\">{{typesConfig[event?.data?.type]?.description}}</span>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"event?.data?.blocked\">\n <div class=\"ui-schedule-event-blocked\">\n <div class=\"ui-event-title\">{{event?.data?.title}}</div>\n <div class=\"ui-event-hour\">\n <tl-icon [lib]=\"'fa'\" [style]=\"'far'\">clock</tl-icon>\n {{event?.data?.date?.start | date: 'dd/yy'}} - {{event?.data?.date?.end | date: 'dd/yy'}}<br>\n </div>\n </div>\n\n </ng-container>\n </div>\n </div>\n </div>\n</div>\n", styles: [".ui-schedule-slats{display:grid;position:relative;grid-template-columns:60px auto;border-top:1px solid #D6D6D6}.ui-schedule-times{color:#949799;font-weight:300;background-color:#fff;border-right:1px solid #D6D6D6}.ui-schedule-time-row{box-sizing:border-box;border-bottom:1px solid #D6D6D6;width:100%;display:flex;justify-content:center}.ui-schedule-time-row:last-child{border-bottom:none}.ui-schedule-time-row>.ui-schedule-time-description{display:block;align-items:baseline}.ui-schedule-time-row>.ui-schedule-time-description .ui-hour-detail{font-weight:700;font-size:1.6em;line-height:1.5}.ui-schedule-widget-rows>.ui-schedule-row{background-color:#f5f5f5;border-bottom:1px #D6D6D6 dotted;cursor:pointer}.ui-schedule-widget-rows>.ui-schedule-row.selected{background-color:#ededed}.ui-schedule-widget-rows>.ui-schedule-row:first-child{border-bottom:1px #D6D6D6 dotted}.ui-schedule-widget-rows>.ui-schedule-row:last-child:not(.last){border-bottom:1px #D6D6D6 solid}.ui-schedule-widget-rows>.ui-schedule-row:last-child{border-bottom:none}.ui-schedule-widget-content{width:100%}.ui-schedule-widget-content .ui-schedule-row{padding-left:10px;content:\" \";box-sizing:border-box}.ui-schedule-widget-content .ui-schedule-row:hover{background-color:#ededed}.ui-schedule-skeleton>.ui-schedule-now-indicator{margin-top:-5px;position:absolute}.ui-schedule-skeleton>.ui-schedule-now-arrow{left:0;border:1px solid red;border-width:5px 0 5px 6px;border-top-color:transparent;border-bottom-color:transparent}.ui-schedule-grid-events{position:absolute;inset:0 0 0 60px;height:0}.ui-schedule-list-events{position:relative}.ui-schedule-event-box{font-family:Segoe UI,Lato,\"sans-serif\",Arial;background-color:#fff;border-radius:4px 4px 2px 2px;border-left-width:5px;border-left-color:transparent;border-left-style:solid;border-top:1px #D6D6D6 solid;border-right:1px #D6D6D6 solid;border-bottom:1px #D6D6D6 solid;-webkit-user-select:none;user-select:none;cursor:pointer;display:flex;box-sizing:border-box;position:absolute}.ui-schedule-event-content{display:flex;width:65%;flex-flow:column;place-content:space-between}.ui-schedule-event-content>.ui-event-data{padding:2px 0 0 5px;line-height:1.3em}.ui-schedule-event-content>.ui-event-data>.ui-event-title{display:flex;height:17px}.ui-schedule-event-content>.ui-event-data>.ui-event-title>.title{font-size:.9em;font-weight:600;color:#454e58;white-space:nowrap;text-overflow:ellipsis}.ui-schedule-event-content>.ui-event-data>.ui-event-title>.tags{display:flex;margin-left:10px}.ui-schedule-event-content>.ui-event-data>.ui-event-title>.tags>.tag-item{border-radius:2px;margin-right:5px;min-width:85px;height:20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8em;white-space:nowrap}.ui-schedule-event-content>.ui-event-data>.ui-event-detail{font-size:.85em;color:#949799;white-space:nowrap;text-overflow:ellipsis}.ui-schedule-event-content>.ui-event-note{font-size:.85em;color:#949799;white-space:nowrap;text-overflow:ellipsis;padding-left:5px}.ui-schedule-event-blocked{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:repeating-linear-gradient(135deg,rgba(245,245,245,.7),rgba(245,245,245,.7) 10px,#FFFFFF 10px,#FFFFFF 20px)}.ui-schedule-event-blocked>.ui-event-title{font-size:1.1em;font-weight:600;color:#454e58;white-space:nowrap;text-overflow:ellipsis;font-variant-caps:all-petite-caps}.ui-schedule-event-blocked>.ui-event-hour{font-size:1.1em;color:#454e58;justify-content:center;margin-right:0}.ui-event-hour{color:#454e58;display:flex;font-size:.88em;justify-content:center;margin-right:10px;width:35%;flex-flow:column;align-items:flex-end}.ui-event-hour>.ui-event-typeconfig-description{font-size:.88em;font-weight:700}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i5.TooltipDirective, selector: "[tooltip]", inputs: ["tooltip"] }, { kind: "component", type: i6.TlIcons, selector: "tl-icon", inputs: ["icon", "lib", "style", "size", "animation", "color", "align"] }, { kind: "pipe", type: i4.DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WeekComponent, decorators: [{ type: Component, args: [{ selector: 'tl-week', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"ui-schedule-slats\"\n *ngFor=\"let times of timesCollection; let timesIndex = index; let lastTurn = last; let firstTurn = first;\">\n\n <!-- CREATE TIMES BOXES-->\n <div class=\"ui-schedule-times\">\n <div class=\"ui-schedule-time-row\"\n *ngFor=\"let time of times\"\n [ngClass]=\"{ firstTurn: firstTurn }\"\n [ngStyle]=\"{\n height: (slotSettings.slotCount * slotSettings.slotHight) + 'px',\n 'align-items': slotSettings.slotCount > 1 ? 'flex-start' : 'center'\n }\">\n <div class=\"ui-schedule-time-description\">\n <span class=\"ui-hour-detail\">{{time | date: 'dd/MM'}}</span><br>\n <span>{{time | date: 'HH:mm'}}</span>\n </div>\n </div>\n </div>\n\n <!-- CREATE WIDGET CONTENT-->\n <div #scheduleSlats class=\"ui-schedule-widget-content\">\n <div *ngFor=\"let time of times; let last = last; let first = first;\" class=\"ui-schedule-widget-rows\">\n <div #scheduleRow class=\"ui-schedule-row\" [attr.data-row-index]=\"time.getTime() * (index+1)\" *ngFor=\"let slot of slatNumberRowsAsArray; let index = index\"\n (click)=\"rowClick( time, index, timesIndex, scheduleRow )\"\n (dblclick)=\"rowDbClick( time, index, timesIndex )\"\n [ngStyle]=\"{ height: slotSettings.slotHight + 'px' }\"\n [ngClass]=\"{ last: last, first: first, lastTurn: lastTurn, firstTurn: firstTurn }\"\n [class.selected]=\"scheduleRow?.getAttribute('data-row-index') === indexRowSelected\">\n </div>\n </div>\n </div>\n\n</div>\n<div class=\"ui-schedule-skeleton\" >\n <div class=\"ui-schedule-grid-events\">\n <div class=\"ui-schedule-list-events\">\n\n <!-- CREATE EVENTS BOXES-->\n <div class=\"ui-schedule-event-box\" [style.borderLeftWidth]=\"event?.data?.blocked ? 0 : '5px'\"\n #elementBox\n *ngFor=\"let event of eventsWithPositions; let index = index\"\n [ngStyle]=\"{\n top: event?.positions.top + 'px',\n left: event?.positions.left + 'px',\n height: event?.positions.height + 'px',\n width: event?.positions.width + 'px'\n }\"\n [style.borderLeftColor]=\"statusConfig ? statusConfig[event?.data?.status]?.color : '#FFFFFF'\"\n [tooltip]=\"{text: statusConfig ? statusConfig[event?.data?.status]?.description : '' , placement: 'top-center'}\"\n (contextmenu)=\"onEventContextmenu.emit( { event: $event, data: event?.data, element: elementBox } ); false\"\n (click)=\"onEventClick.emit( event?.data )\"\n (dblclick)=\"onEventDbClick.emit( event?.data )\"\n (mouseover)=\"onEventMouseout.emit( event?.data )\"\n (mouseout)=\"onEventMouseout.emit( event?.data )\"\n >\n <ng-container *ngIf=\"!event?.data?.blocked\">\n <div class=\"ui-schedule-event-content\">\n <div class=\"ui-event-data\">\n <div class=\"ui-event-title\">\n <span class=\"title\">{{event?.data?.title}}</span>\n <div class=\"tags\" *ngIf=\"event?.data?.tags?.length > 0 \">\n <div class=\"tag-item\" *ngFor=\"let tag of event?.data?.tags;\" [style.backgroundColor]=\"tag.color\" >\n {{tag.title}}\n </div>\n </div>\n </div>\n <div class=\"ui-event-detail\">{{event?.data?.detail}}</div>\n </div>\n <div class=\"ui-event-note\">\n {{event?.data?.note}}\n </div>\n </div>\n <div class=\"ui-event-hour\">\n <span>{{event?.data?.date?.start | date: 'dd/yy'}} - {{event?.data?.date?.end | date: 'dd/yy'}}</span>\n <span class=\"ui-event-typeconfig-description\">{{typesConfig[event?.data?.type]?.description}}</span>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"event?.data?.blocked\">\n <div class=\"ui-schedule-event-blocked\">\n <div class=\"ui-event-title\">{{event?.data?.title}}</div>\n <div class=\"ui-event-hour\">\n <tl-icon [lib]=\"'fa'\" [style]=\"'far'\">clock</tl-icon>\n {{event?.data?.date?.start | date: 'dd/yy'}} - {{event?.data?.date?.end | date: 'dd/yy'}}<br>\n </div>\n </div>\n\n </ng-container>\n </div>\n </div>\n </div>\n</div>\n", styles: [".ui-schedule-slats{display:grid;position:relative;grid-template-columns:60px auto;border-top:1px solid #D6D6D6}.ui-schedule-times{color:#949799;font-weight:300;background-color:#fff;border-right:1px solid #D6D6D6}.ui-schedule-time-row{box-sizing:border-box;border-bottom:1px solid #D6D6D6;width:100%;display:flex;justify-content:center}.ui-schedule-time-row:last-child{border-bottom:none}.ui-schedule-time-row>.ui-schedule-time-description{display:block;align-items:baseline}.ui-schedule-time-row>.ui-schedule-time-description .ui-hour-detail{font-weight:700;font-size:1.6em;line-height:1.5}.ui-schedule-widget-rows>.ui-schedule-row{background-color:#f5f5f5;border-bottom:1px #D6D6D6 dotted;cursor:pointer}.ui-schedule-widget-rows>.ui-schedule-row.selected{background-color:#ededed}.ui-schedule-widget-rows>.ui-schedule-row:first-child{border-bottom:1px #D6D6D6 dotted}.ui-schedule-widget-rows>.ui-schedule-row:last-child:not(.last){border-bottom:1px #D6D6D6 solid}.ui-schedule-widget-rows>.ui-schedule-row:last-child{border-bottom:none}.ui-schedule-widget-content{width:100%}.ui-schedule-widget-content .ui-schedule-row{padding-left:10px;content:\" \";box-sizing:border-box}.ui-schedule-widget-content .ui-schedule-row:hover{background-color:#ededed}.ui-schedule-skeleton>.ui-schedule-now-indicator{margin-top:-5px;position:absolute}.ui-schedule-skeleton>.ui-schedule-now-arrow{left:0;border:1px solid red;border-width:5px 0 5px 6px;border-top-color:transparent;border-bottom-color:transparent}.ui-schedule-grid-events{position:absolute;inset:0 0 0 60px;height:0}.ui-schedule-list-events{position:relative}.ui-schedule-event-box{font-family:Segoe UI,Lato,\"sans-serif\",Arial;background-color:#fff;border-radius:4px 4px 2px 2px;border-left-width:5px;border-left-color:transparent;border-left-style:solid;border-top:1px #D6D6D6 solid;border-right:1px #D6D6D6 solid;border-bottom:1px #D6D6D6 solid;-webkit-user-select:none;user-select:none;cursor:pointer;display:flex;box-sizing:border-box;position:absolute}.ui-schedule-event-content{display:flex;width:65%;flex-flow:column;place-content:space-between}.ui-schedule-event-content>.ui-event-data{padding:2px 0 0 5px;line-height:1.3em}.ui-schedule-event-content>.ui-event-data>.ui-event-title{display:flex;height:17px}.ui-schedule-event-content>.ui-event-data>.ui-event-title>.title{font-size:.9em;font-weight:600;color:#454e58;white-space:nowrap;text-overflow:ellipsis}.ui-schedule-event-content>.ui-event-data>.ui-event-title>.tags{display:flex;margin-left:10px}.ui-schedule-event-content>.ui-event-data>.ui-event-title>.tags>.tag-item{border-radius:2px;margin-right:5px;min-width:85px;height:20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8em;white-space:nowrap}.ui-schedule-event-content>.ui-event-data>.ui-event-detail{font-size:.85em;color:#949799;white-space:nowrap;text-overflow:ellipsis}.ui-schedule-event-content>.ui-event-note{font-size:.85em;color:#949799;white-space:nowrap;text-overflow:ellipsis;padding-left:5px}.ui-schedule-event-blocked{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:repeating-linear-gradient(135deg,rgba(245,245,245,.7),rgba(245,245,245,.7) 10px,#FFFFFF 10px,#FFFFFF 20px)}.ui-schedule-event-blocked>.ui-event-title{font-size:1.1em;font-weight:600;color:#454e58;white-space:nowrap;text-overflow:ellipsis;font-variant-caps:all-petite-caps}.ui-schedule-event-blocked>.ui-event-hour{font-size:1.1em;color:#454e58;justify-content:center;margin-right:0}.ui-event-hour{color:#454e58;display:flex;font-size:.88em;justify-content:center;margin-right:10px;width:35%;flex-flow:column;align-items:flex-end}.ui-event-hour>.ui-event-typeconfig-description{font-size:.88em;font-weight:700}\n"] }] }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.GenerateEventsService }, { type: i2.EventService }, { type: i3.WorkScaleService }]; }, propDecorators: { statusConfig: [{ type: Input }], typesConfig: [{ type: Input }], showNowIndicator: [{ type: Input }], slotSettings: [{ type: Input }], workScale: [{ type: Input }], slatNumberRowsAsArray: [{ type: Input }], texts: [{ type: Input }], events: [{ type: Input, args: ['events'] }], scheduleSlats: [{ type: ViewChildren, args: ['scheduleSlats'] }], onRowDbClick: [{ type: Output }], onRowClick: [{ type: Output }], onEventDbClick: [{ type: Output }], onEventClick: [{ type: Output }], onEventMouseover: [{ type: Output }], onEventMouseout: [{ type: Output }], onEventContextmenu: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"week.component.js","sourceRoot":"","sources":["../../../../../../projects/truly-ui/src/components/schedule/views/week/week.component.ts","../../../../../../projects/truly-ui/src/components/schedule/views/week/week.component.html"],"names":[],"mappings":"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