2021-06-17 16:30:51 +02:00
|
|
|
import { egw } from "../../api/js/jsapi/egw_global";
|
2021-06-11 11:31:06 +02:00
|
|
|
export class View {
|
2020-03-05 13:21:02 +01:00
|
|
|
/**
|
|
|
|
* Translated label for header
|
|
|
|
* @param {Object} state
|
|
|
|
* @returns {string}
|
|
|
|
*/
|
2021-06-11 11:31:06 +02:00
|
|
|
static header(state) {
|
|
|
|
let formatDate = new Date(state.date);
|
2020-03-05 13:21:02 +01:00
|
|
|
formatDate = new Date(formatDate.valueOf() + formatDate.getTimezoneOffset() * 60 * 1000);
|
|
|
|
return View._owner(state) + date(egw.preference('dateformat'), formatDate);
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
2020-03-05 13:21:02 +01:00
|
|
|
/**
|
|
|
|
* If one owner, get the owner text
|
|
|
|
*
|
|
|
|
* @param {object} state
|
|
|
|
*/
|
2021-06-11 11:31:06 +02:00
|
|
|
static _owner(state) {
|
|
|
|
let owner = '';
|
2020-03-05 13:21:02 +01:00
|
|
|
if (state.owner.length && state.owner.length == 1 && app.calendar.sidebox_et2) {
|
|
|
|
var own = app.calendar.sidebox_et2.getWidgetById('owner').getDOMNode();
|
|
|
|
if (own.selectedIndex >= 0) {
|
|
|
|
owner = own.options[own.selectedIndex].innerHTML + ": ";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return owner;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
2020-03-05 13:21:02 +01:00
|
|
|
/**
|
|
|
|
* Get the start date for this view
|
|
|
|
* @param {Object} state
|
|
|
|
* @returns {Date}
|
|
|
|
*/
|
2021-06-11 11:31:06 +02:00
|
|
|
static start_date(state) {
|
|
|
|
const d = state.date ? new Date(state.date) : new Date();
|
2020-03-05 13:21:02 +01:00
|
|
|
d.setUTCHours(0);
|
|
|
|
d.setUTCMinutes(0);
|
|
|
|
d.setUTCSeconds(0);
|
|
|
|
d.setUTCMilliseconds(0);
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
2020-03-05 13:21:02 +01:00
|
|
|
/**
|
|
|
|
* Get the end date for this view
|
|
|
|
* @param {Object} state
|
|
|
|
* @returns {Date}
|
|
|
|
*/
|
2021-06-11 11:31:06 +02:00
|
|
|
static end_date(state) {
|
|
|
|
const d = state.date ? new Date(state.date) : new Date();
|
2020-03-05 13:21:02 +01:00
|
|
|
d.setUTCHours(23);
|
|
|
|
d.setUTCMinutes(59);
|
|
|
|
d.setUTCSeconds(59);
|
|
|
|
d.setUTCMilliseconds(0);
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
2020-03-05 13:21:02 +01:00
|
|
|
/**
|
|
|
|
* Get the owner for this view
|
|
|
|
*
|
|
|
|
* This is always the owner from the given state, we use a function
|
|
|
|
* to trigger setting the widget value.
|
|
|
|
*
|
|
|
|
* @param {number[]|String} state state.owner List of owner IDs, or a comma seperated list
|
|
|
|
* @returns {number[]|String}
|
|
|
|
*/
|
2021-06-11 11:31:06 +02:00
|
|
|
static owner(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
return state.owner || 0;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
2020-03-05 13:21:02 +01:00
|
|
|
/**
|
|
|
|
* Should the view show the weekends
|
|
|
|
*
|
|
|
|
* @param {object} state
|
|
|
|
* @returns {boolean} Current preference to show 5 or 7 days in weekview
|
|
|
|
*/
|
2021-06-11 11:31:06 +02:00
|
|
|
static show_weekend(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
return state.weekend;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
2020-03-05 13:21:02 +01:00
|
|
|
/**
|
|
|
|
* How big or small are the displayed time chunks?
|
|
|
|
*
|
|
|
|
* @param {object} state
|
|
|
|
*/
|
2021-06-11 11:31:06 +02:00
|
|
|
static granularity(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var list = egw.preference('use_time_grid', 'calendar');
|
|
|
|
if (list == '0' || typeof list === 'undefined') {
|
|
|
|
return parseInt('' + egw.preference('interval', 'calendar')) || 30;
|
|
|
|
}
|
|
|
|
if (typeof list == 'string')
|
|
|
|
list = list.split(',');
|
|
|
|
if (!list.indexOf && jQuery.isPlainObject(list)) {
|
|
|
|
list = jQuery.map(list, function (el) {
|
|
|
|
return el;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
return list.indexOf(state.view) >= 0 ?
|
|
|
|
0 :
|
|
|
|
parseInt(egw.preference('interval', 'calendar')) || 30;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static extend(sub) {
|
2020-03-05 13:21:02 +01:00
|
|
|
return jQuery.extend({}, this, { _super: this }, sub);
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
2020-03-05 13:21:02 +01:00
|
|
|
/**
|
|
|
|
* Determines the new date after scrolling. The default is 1 week.
|
|
|
|
*
|
|
|
|
* @param {number} delta Integer for how many 'ticks' to move, positive for
|
|
|
|
* forward, negative for backward
|
|
|
|
* @returns {Date}
|
|
|
|
*/
|
2021-06-11 11:31:06 +02:00
|
|
|
static scroll(delta) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var d = new Date(app.calendar.state.date);
|
|
|
|
d.setUTCDate(d.getUTCDate() + (7 * delta));
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// List of etemplates to show for this view
|
|
|
|
View.etemplates = ['calendar.view'];
|
2020-03-05 13:21:02 +01:00
|
|
|
/**
|
|
|
|
* Etemplates and settings for the different views. Some (day view)
|
|
|
|
* use more than one template, some use the same template as others,
|
|
|
|
* most need different handling for their various attributes.
|
|
|
|
*/
|
2021-06-11 11:31:06 +02:00
|
|
|
export class day extends View {
|
|
|
|
static header(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var formatDate = new Date(state.date);
|
|
|
|
formatDate = new Date(formatDate.valueOf() + formatDate.getTimezoneOffset() * 60 * 1000);
|
2021-06-11 11:31:06 +02:00
|
|
|
return date('l, ', formatDate) + super.header(state);
|
|
|
|
}
|
|
|
|
static start_date(state) {
|
|
|
|
var d = super.start_date(state);
|
2020-03-05 13:21:02 +01:00
|
|
|
state.date = app.calendar.date.toString(d);
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static show_weekend(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
state.days = '1';
|
|
|
|
return true;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static scroll(delta) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var d = new Date(app.calendar.state.date);
|
|
|
|
d.setUTCDate(d.getUTCDate() + (delta));
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
day.etemplates = ['calendar.view', 'calendar.todo'];
|
|
|
|
export class day4 extends View {
|
|
|
|
static end_date(state) {
|
|
|
|
var d = super.end_date(state);
|
2020-03-05 13:21:02 +01:00
|
|
|
state.days = '4';
|
|
|
|
d.setUTCHours(24 * 4 - 1);
|
|
|
|
d.setUTCMinutes(59);
|
|
|
|
d.setUTCSeconds(59);
|
|
|
|
d.setUTCMilliseconds(0);
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static show_weekend(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
state.weekend = 'true';
|
|
|
|
return true;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static scroll(delta) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var d = new Date(app.calendar.state.date);
|
|
|
|
d.setUTCDate(d.getUTCDate() + (4 * delta));
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
export class week extends View {
|
|
|
|
static header(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var end_date = state.last;
|
|
|
|
if (!week.show_weekend(state)) {
|
|
|
|
end_date = new Date(state.last);
|
|
|
|
end_date.setUTCDate(end_date.getUTCDate() - 2);
|
|
|
|
}
|
2021-06-11 11:31:06 +02:00
|
|
|
return super._owner(state) + app.calendar.egw.lang('Week') + ' ' +
|
2020-03-05 13:21:02 +01:00
|
|
|
app.calendar.date.week_number(state.first) + ': ' +
|
|
|
|
app.calendar.date.long_date(state.first, end_date);
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static start_date(state) {
|
|
|
|
return app.calendar.date.start_of_week(super.start_date(state));
|
|
|
|
}
|
|
|
|
static end_date(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var d = app.calendar.date.start_of_week(state.date || new Date());
|
|
|
|
// Always 7 days, we just turn weekends on or off
|
|
|
|
d.setUTCHours(24 * 7 - 1);
|
|
|
|
d.setUTCMinutes(59);
|
|
|
|
d.setUTCSeconds(59);
|
|
|
|
d.setUTCMilliseconds(0);
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
export class weekN extends View {
|
|
|
|
static header(state) {
|
|
|
|
return super._owner(state) + app.calendar.egw.lang('Week') + ' ' +
|
2020-03-05 13:21:02 +01:00
|
|
|
app.calendar.date.week_number(state.first) + ' - ' +
|
|
|
|
app.calendar.date.week_number(state.last) + ': ' +
|
|
|
|
app.calendar.date.long_date(state.first, state.last);
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static start_date(state) {
|
|
|
|
return app.calendar.date.start_of_week(super.start_date(state));
|
|
|
|
}
|
|
|
|
static end_date(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
state.days = '' + (state.days >= 5 ? state.days : egw.preference('days_in_weekview', 'calendar') || 7);
|
2021-06-11 11:31:06 +02:00
|
|
|
var d = app.calendar.date.start_of_week(super.start_date(state));
|
2020-03-05 13:21:02 +01:00
|
|
|
// Always 7 days, we just turn weekends on or off
|
2020-05-21 22:07:29 +02:00
|
|
|
d.setUTCHours(24 * 7 * (parseInt(app.calendar.egw.preference('multiple_weeks', 'calendar')) || 3) - 1);
|
2020-03-05 13:21:02 +01:00
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
export class month extends View {
|
|
|
|
static header(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var formatDate = new Date(state.date);
|
|
|
|
formatDate = new Date(formatDate.valueOf() + formatDate.getTimezoneOffset() * 60 * 1000);
|
2021-06-11 11:31:06 +02:00
|
|
|
return super._owner(state) + app.calendar.egw.lang(date('F', formatDate)) + ' ' + date('Y', formatDate);
|
|
|
|
}
|
|
|
|
static start_date(state) {
|
|
|
|
var d = super.start_date(state);
|
2020-03-05 13:21:02 +01:00
|
|
|
d.setUTCDate(1);
|
|
|
|
return app.calendar.date.start_of_week(d);
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static end_date(state) {
|
|
|
|
var d = super.end_date(state);
|
2020-03-05 13:21:02 +01:00
|
|
|
d = new Date(d.getFullYear(), d.getUTCMonth() + 1, 1, 0, -d.getTimezoneOffset(), 0);
|
|
|
|
d.setUTCSeconds(d.getUTCSeconds() - 1);
|
|
|
|
return app.calendar.date.end_of_week(d);
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static scroll(delta) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var d = new Date(app.calendar.state.date);
|
|
|
|
// Set day to 15 so we don't get overflow on short months
|
|
|
|
// eg. Aug 31 + 1 month = Sept 31 -> Oct 1
|
|
|
|
d.setUTCDate(15);
|
|
|
|
d.setUTCMonth(d.getUTCMonth() + delta);
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
export class planner extends View {
|
|
|
|
static header(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var startDate = new Date(state.first);
|
|
|
|
startDate = new Date(startDate.valueOf() + startDate.getTimezoneOffset() * 60 * 1000);
|
|
|
|
var endDate = new Date(state.last);
|
|
|
|
endDate = new Date(endDate.valueOf() + endDate.getTimezoneOffset() * 60 * 1000);
|
2021-06-11 11:31:06 +02:00
|
|
|
return super._owner(state) + date(egw.preference('dateformat'), startDate) +
|
2020-03-05 13:21:02 +01:00
|
|
|
(startDate == endDate ? '' : ' - ' + date(egw.preference('dateformat'), endDate));
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static group_by(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
return state.sortby ? state.sortby : 0;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
2020-03-05 13:21:02 +01:00
|
|
|
// Note: Planner uses the additional value of planner_view to determine
|
|
|
|
// the start & end dates using other view's functions
|
2021-06-11 11:31:06 +02:00
|
|
|
static start_date(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
// Start here, in case we can't find anything better
|
2021-06-11 11:31:06 +02:00
|
|
|
var d = super.start_date(state);
|
2020-03-05 13:21:02 +01:00
|
|
|
if (state.sortby && state.sortby === 'month') {
|
|
|
|
d.setUTCDate(1);
|
|
|
|
}
|
|
|
|
else if (state.planner_view && app.classes.calendar.views[state.planner_view]) {
|
|
|
|
d = app.classes.calendar.views[state.planner_view].start_date.call(this, state);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
d = app.calendar.date.start_of_week(d);
|
|
|
|
d.setUTCHours(0);
|
|
|
|
d.setUTCMinutes(0);
|
|
|
|
d.setUTCSeconds(0);
|
|
|
|
d.setUTCMilliseconds(0);
|
|
|
|
return d;
|
|
|
|
}
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static end_date(state) {
|
|
|
|
var d = super.end_date(state);
|
2020-03-05 13:21:02 +01:00
|
|
|
if (state.sortby && state.sortby === 'month') {
|
|
|
|
d.setUTCDate(0);
|
|
|
|
d.setUTCFullYear(d.getUTCFullYear() + 1);
|
|
|
|
}
|
|
|
|
else if (state.planner_view && app.classes.calendar.views[state.planner_view]) {
|
|
|
|
d = app.classes.calendar.views[state.planner_view].end_date(state);
|
|
|
|
}
|
|
|
|
else if (state.days) {
|
|
|
|
// This one comes from a grid view, but we'll use it
|
|
|
|
d.setUTCDate(d.getUTCDate() + parseInt(state.days) - 1);
|
|
|
|
delete state.days;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
d = app.calendar.date.end_of_week(d);
|
|
|
|
}
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static hide_empty(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var check = state.sortby == 'user' ? ['user', 'both'] : ['cat', 'both'];
|
|
|
|
return (check.indexOf(egw.preference('planner_show_empty_rows', 'calendar') + '') === -1);
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
static scroll(delta) {
|
2021-01-11 18:23:07 +01:00
|
|
|
if (app.calendar.state.planner_view && !isNaN(delta) && app.calendar.state.sortby !== "month") {
|
2020-03-05 13:21:02 +01:00
|
|
|
return app.classes.calendar.views[app.calendar.state.planner_view].scroll(delta);
|
|
|
|
}
|
2021-06-11 11:31:06 +02:00
|
|
|
let d = new Date(app.calendar.state.date);
|
|
|
|
let days = 1;
|
2021-01-11 18:23:07 +01:00
|
|
|
delta = parseInt(delta) || 0;
|
2020-03-05 13:21:02 +01:00
|
|
|
// Yearly view, grouped by month - scroll 1 month
|
|
|
|
if (app.calendar.state.sortby === 'month') {
|
|
|
|
d.setUTCMonth(d.getUTCMonth() + delta);
|
|
|
|
d.setUTCDate(1);
|
|
|
|
d.setUTCHours(0);
|
|
|
|
d.setUTCMinutes(0);
|
|
|
|
return d;
|
|
|
|
}
|
|
|
|
// Need to set the day count, or auto date ranging takes over and
|
|
|
|
// makes things buggy
|
|
|
|
if (app.calendar.state.first && app.calendar.state.last) {
|
2021-01-11 18:23:07 +01:00
|
|
|
//@ts-ignore
|
2021-06-11 11:31:06 +02:00
|
|
|
let diff = new Date(app.calendar.state.last) - new Date(app.calendar.state.first);
|
2020-03-05 13:21:02 +01:00
|
|
|
days = Math.round(diff / (1000 * 3600 * 24));
|
|
|
|
}
|
|
|
|
d.setUTCDate(d.getUTCDate() + (days * delta));
|
|
|
|
if (days > 8) {
|
|
|
|
d = app.calendar.date.start_of_week(d);
|
|
|
|
}
|
|
|
|
return d;
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
planner.etemplates = ['calendar.planner'];
|
|
|
|
export class listview extends View {
|
|
|
|
static header(state) {
|
2020-03-05 13:21:02 +01:00
|
|
|
var startDate = new Date(state.first || state.date);
|
|
|
|
startDate = new Date(startDate.valueOf() + startDate.getTimezoneOffset() * 60 * 1000);
|
|
|
|
var start_check = '' + startDate.getFullYear() + startDate.getMonth() + startDate.getDate();
|
|
|
|
var endDate = new Date(state.last || state.date);
|
|
|
|
endDate = new Date(endDate.valueOf() + endDate.getTimezoneOffset() * 60 * 1000);
|
|
|
|
var end_check = '' + endDate.getFullYear() + endDate.getMonth() + endDate.getDate();
|
2021-06-11 11:31:06 +02:00
|
|
|
return super._owner(state) +
|
2020-03-05 13:21:02 +01:00
|
|
|
date(egw.preference('dateformat'), startDate) +
|
|
|
|
(start_check == end_check ? '' : ' - ' + date(egw.preference('dateformat'), endDate));
|
2021-06-11 11:31:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
listview.etemplates = ['calendar.list'];
|
2020-03-05 13:21:02 +01:00
|
|
|
//# sourceMappingURL=View.js.map
|