|
1 |
| -(function (global, doc, ibexa, Translator, moment) { |
| 1 | +(function (global, doc, ibexa, Translator, bootstrap, moment) { |
2 | 2 | const ENTER_KEY_CODE = 13;
|
3 | 3 | const STATUS_ERROR = 'error';
|
4 | 4 | const STATUS_OFF = 'off';
|
|
30 | 30 | const submitBtns = form.querySelectorAll('[type="submit"]:not([formnovalidate])');
|
31 | 31 | const menuButtonsToValidate = doc.querySelectorAll('button[data-validate]');
|
32 | 32 | const fields = doc.querySelectorAll('.ibexa-field-edit');
|
| 33 | + const autosaveNode = doc.querySelector('.ibexa-autosave'); |
33 | 34 | const getValidationResults = (validator) => {
|
34 | 35 | const isValid = validator.isValid();
|
35 | 36 | const validatorName = validator.constructor.name;
|
|
130 | 131 | return ibexa.adminUiConfig.autosave.enabled && form.querySelector('[name="ezplatform_content_forms_content_edit[autosave]"]');
|
131 | 132 | };
|
132 | 133 |
|
133 |
| - if (isAutosaveEnabled()) { |
134 |
| - const AUTOSAVE_SUBMIT_BUTTON_NAME = 'ezplatform_content_forms_content_edit[autosave]'; |
135 |
| - const autosave = doc.querySelector('.ibexa-autosave'); |
136 |
| - const autosaveStatusSavedNode = autosave.querySelector('.ibexa-autosave__status-saved'); |
137 |
| - let currentAutosaveStatus = autosave.classList.contains('ibexa-autosave--on') ? STATUS_ON : STATUS_OFF; |
| 134 | + if (autosaveNode) { |
| 135 | + let currentAutosaveStatus = autosaveNode.classList.contains('ibexa-autosave--on') ? STATUS_ON : STATUS_OFF; |
| 136 | + let isAutosaveSimple = autosaveNode.classList.contains('ibexa-autosave--simple'); |
| 137 | + const tooltipInstance = bootstrap.Tooltip.getOrCreateInstance(autosaveNode); |
138 | 138 | const generateCssStatusClass = (status) => `ibexa-autosave--${status}`;
|
139 | 139 | const setAutosaveStatus = (newStatus) => {
|
140 |
| - if (!autosave) { |
141 |
| - return; |
142 |
| - } |
143 |
| - |
144 | 140 | const oldCssStatusClass = generateCssStatusClass(currentAutosaveStatus);
|
145 | 141 | const newCssStatusClass = generateCssStatusClass(newStatus);
|
146 | 142 |
|
147 |
| - autosave.classList.remove(oldCssStatusClass); |
148 |
| - autosave.classList.remove('ibexa-autosave--saved'); |
149 |
| - autosave.classList.add(newCssStatusClass); |
| 143 | + autosaveNode.classList.remove(oldCssStatusClass); |
| 144 | + autosaveNode.classList.remove('ibexa-autosave--saved'); |
| 145 | + autosaveNode.classList.add(newCssStatusClass); |
150 | 146 |
|
151 | 147 | currentAutosaveStatus = newStatus;
|
| 148 | + setAutosaveTooltipContent(); |
152 | 149 | };
|
153 |
| - const setDraftSavedMessage = () => { |
154 |
| - if (!autosave) { |
155 |
| - return; |
156 |
| - } |
157 |
| - |
| 150 | + const setAutosaveTooltipContent = () => { |
| 151 | + const statusMsgFromNode = autosaveNode.querySelector(`.ibexa-autosave__status--${currentAutosaveStatus}`).innerText; |
| 152 | + const tooltipContent = isAutosaveSimple |
| 153 | + ? statusMsgFromNode |
| 154 | + : Translator.trans( |
| 155 | + /*@Desc("You can turn autosave off in your user settings")*/ 'content.autosave.turn_off.message', |
| 156 | + {}, |
| 157 | + 'ibexa_content', |
| 158 | + ); |
| 159 | + |
| 160 | + tooltipInstance.setContent({ '.tooltip-inner': tooltipContent }); |
| 161 | + }; |
| 162 | + const setDraftSavedMessage = (autosaveStatusSavedNode) => { |
158 | 163 | const userPreferredTimezone = ibexa.adminUiConfig.timezone;
|
159 | 164 | const saveDate = ibexa.helpers.timezone.convertDateToTimezone(new Date(), userPreferredTimezone);
|
160 | 165 | const saveTime = moment(saveDate).formatICU('HH:mm');
|
|
165 | 170 | );
|
166 | 171 |
|
167 | 172 | autosaveStatusSavedNode.innerHTML = saveMessage;
|
168 |
| - autosave.classList.add('ibexa-autosave--saved'); |
| 173 | + autosaveNode.classList.add('ibexa-autosave--saved'); |
169 | 174 | };
|
170 | 175 |
|
171 |
| - setInterval(() => { |
172 |
| - const formData = new FormData(form); |
173 |
| - |
174 |
| - formData.set(AUTOSAVE_SUBMIT_BUTTON_NAME, true); |
175 |
| - setAutosaveStatus(STATUS_SAVING); |
176 |
| - |
177 |
| - fetch(form.target || window.location.href, { method: 'POST', body: formData }) |
178 |
| - .then(ibexa.helpers.request.getStatusFromResponse) |
179 |
| - .then(() => { |
180 |
| - setAutosaveStatus(STATUS_SAVED); |
181 |
| - setDraftSavedMessage(); |
182 |
| - }) |
183 |
| - .catch(() => { |
184 |
| - setAutosaveStatus(STATUS_ERROR); |
185 |
| - }); |
186 |
| - }, ibexa.adminUiConfig.autosave.interval); |
| 176 | + setAutosaveTooltipContent(); |
| 177 | + |
| 178 | + doc.body.addEventListener('ibexa:edit-content-change-header-size', ({ detail }) => { |
| 179 | + isAutosaveSimple = detail.isHeaderSlim; |
| 180 | + autosaveNode.classList.toggle('ibexa-autosave--simple', isAutosaveSimple); |
| 181 | + setAutosaveTooltipContent(); |
| 182 | + }); |
| 183 | + |
| 184 | + if (isAutosaveEnabled()) { |
| 185 | + const AUTOSAVE_SUBMIT_BUTTON_NAME = 'ezplatform_content_forms_content_edit[autosave]'; |
| 186 | + const autosaveStatusSavedNode = autosaveNode.querySelector('.ibexa-autosave__status--saved'); |
| 187 | + |
| 188 | + setInterval(() => { |
| 189 | + const formData = new FormData(form); |
| 190 | + |
| 191 | + formData.set(AUTOSAVE_SUBMIT_BUTTON_NAME, true); |
| 192 | + setAutosaveStatus(STATUS_SAVING); |
| 193 | + |
| 194 | + fetch(form.target || window.location.href, { method: 'POST', body: formData }) |
| 195 | + .then(ibexa.helpers.request.getStatusFromResponse) |
| 196 | + .then(() => { |
| 197 | + setAutosaveStatus(STATUS_SAVED); |
| 198 | + setDraftSavedMessage(autosaveStatusSavedNode); |
| 199 | + }) |
| 200 | + .catch(() => { |
| 201 | + setAutosaveStatus(STATUS_ERROR); |
| 202 | + }) |
| 203 | + .finally(() => { |
| 204 | + setAutosaveTooltipContent(); |
| 205 | + }); |
| 206 | + }, ibexa.adminUiConfig.autosave.interval); |
| 207 | + } |
187 | 208 | }
|
188 | 209 |
|
189 | 210 | form.setAttribute('novalidate', true);
|
|
204 | 225 | menuButtonsToValidate.forEach((btn) => {
|
205 | 226 | btn.addEventListener('click', validateHandler, false);
|
206 | 227 | });
|
207 |
| -})(window, window.document, window.ibexa, window.Translator, window.moment); |
| 228 | +})(window, window.document, window.ibexa, window.Translator, window.bootstrap, window.moment); |
0 commit comments