-
Notifications
You must be signed in to change notification settings - Fork 0
/
tix-bookmarklet.js
105 lines (87 loc) · 7.98 KB
/
tix-bookmarklet.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
const bookmarkletCode = () => {
const version = 'v3.0.0';
const loadjQuery = (callback) => {
const script = document.createElement('script');
script.src = 'https://code.jquery.com/jquery-3.7.1.slim.js';
script.type = 'text/javascript';
script.onload = callback;
document.head.appendChild(script);
};
const cleanTix = () => {
const body$ = $('body');
const cleaned = body$.data('cleaned');
function mergeMatrixRows(matrixContainer$) {
const matrix$ = matrixContainer$.find('.matrix-component:eq(0)');
matrix$.find('.type-of-work-title:contains(Direct hours)').each((v, el) => {
const $el = $(el);
const $topLevel = $el.parent().parent().prev();
const startIndexName = $topLevel.text().search(/[a-zA-Z]/);
const dsc = $topLevel.text().substring(startIndexName);
$el.find('.title-part-item').append(': ' + dsc);
$topLevel.hide();
});
}
if (!cleaned) {
const matrixContainer$ = $('.webGrid:eq(0)');
mergeMatrixRows(matrixContainer$);
const observer = new MutationObserver((mutationsList, observer) => {
if (mutationsList.filter(m => m.target.classList.contains('matrix-component')).length > 0) {
mergeMatrixRows(matrixContainer$);
}
});
observer.observe(document.getElementsByClassName('webGrid')[0], {
attributes: true,
childList: false,
subtree: true
});
matrixContainer$.on('focus', '.matrix-component .input', (el) => {
const index = $(el.currentTarget).parents('.matrix-cell-component').index() + 1;
$('.matrix-cell-component:nth-child(' + index + ')').addClass('is-focussed')
});
matrixContainer$.on('blur', '.matrix-component .input', () => {
$('.matrix-cell-component').removeClass('is-focussed');
});
const sidePanel$ = $('.webGrid-side-panel');
const toggleSidePanelBtn$ = $('<img src="">');
toggleSidePanelBtn$.on('click', () => sidePanel$.toggle());
const ufoBtn$ = $('<img src="">');
ufoBtn$.on('click', () => body$.toggleClass('ufo'));
const ufoTitle$ = $('<span class="ufo-title"><img src="" /> UFO</span>');
$('.icons-right').prepend([ufoTitle$, ufoBtn$, toggleSidePanelBtn$]);
const cleanTixVersion$ = $('<div class="clean-tix-version"><a href="https://waterstraal.github.io/clean-tix/" target="_blank">Clean TIX ' + version + '</a></div>');
$('body').append([cleanTixVersion$]);
const styles =
'.weeknr { background-color: antiquewhite !important; font-size: 0.7em !important; font-style: italic; } ' +
'.type-of-work-title .toggle {display: none !important;} ' +
'.nested-matrix-row-component-level-2>div:first-child {margin-left:20px !important;} ' +
'.is-focussed, .is-focussed .input { background-color: lightyellow !important;} ' +
'.input { transition: none !important;} ' +
'.input:focus, .input:hover { outline-style: auto !important; outline-offset: -2px !important; box-shadow: none !important;}' +
'.input:focus { background-color: white !important; } ' +
'.matrix-cell-component-column-title { overflow: hidden !important; } ' +
'.title__day-name { visibility: hidden !important; } ' +
'.title__day-name:first-letter { visibility: visible !important; } ' +
'.enlarge-icon { display: none !important; } ' +
'.icons-right > * { cursor: pointer !important; } ' +
'.clean-tix-version { text-align:center; padding: 4px; } ' +
'.clean-tix-version a { color:lightgray; font-size:10px; } ' +
'.rea-list-icon.remove, .ufo-title { display:none; } ' +
'.ufo.sitebackground { background: #FFC080 }' +
'.ufo #P_C_W_Gridform_Grid { border: 1px solid #343434; border-radius: 10px; overflow: hidden; }' +
'.ufo .partheader, .ufo .pagetitle, .ufo .masterheaderback { display: none; }' +
'.ufo .ufo-title { display: initial; position: absolute; left: 8px; padding-top: 3px; }' +
'.ufo .ufo-title img { display: inline-block; }' +
'.ufo .webGrid-header-bar { position: relative; }' +
'.ufo .matrix-row-component:not(.nested-matrix-row-component-level-last), .ufo .is-aggregation, .ufo .webGrid .matrix-component>.matrix-row-component.header { background: #F0F0F0 !important; color: #000000 !important; } ' +
'.ufo .calendar-header-day-title, .ufo .matrix-cell-component-title { color: inherit !important; } ' +
'.ufo .webGrid-header-bar { height: 32px; margin: 0; background: rgb(255,255,255); background: linear-gradient(0deg, rgba(255,255,255,1) 0%, rgba(152,180,208,1) 1%, rgba(164,190,217,1) 50%, rgba(185,209,234,1) 100%); }';
$('<style>').text(styles).appendTo(document.head);
body$.data('cleaned', true);
}
};
if (typeof jQuery === 'undefined') {
loadjQuery(cleanTix);
} else {
cleanTix();
}
};