Skip to content

Commit

Permalink
[DE][DE embed] Fix Bug 67561: open docxf/oform as pdf-form
Browse files Browse the repository at this point in the history
  • Loading branch information
JuliaRadzhabova committed Apr 22, 2024
1 parent 6cb833b commit 1e16c5c
Show file tree
Hide file tree
Showing 9 changed files with 48 additions and 10 deletions.
11 changes: 7 additions & 4 deletions apps/api/documents/api.js
Original file line number Diff line number Diff line change
Expand Up @@ -1076,15 +1076,18 @@
if (config.frameEditorId)
params += "&frameEditorId=" + config.frameEditorId;

var type = config.document ? /^(?:(pdf))$/.exec(config.document.fileType) : null;
if (!(type && typeof type[1] === 'string') && (config.editorConfig && config.editorConfig.mode == 'view' ||
var type = config.document ? /^(?:(pdf)|(oform|docxf))$/.exec(config.document.fileType) : null,
isPdf = type && typeof type[1] === 'string',
oldForm = type && typeof type[2] === 'string';

if (!(isPdf || oldForm) && (config.editorConfig && config.editorConfig.mode == 'view' ||
config.document && config.document.permissions && (config.document.permissions.edit === false && !config.document.permissions.review )))
params += "&mode=view";
if (type && typeof type[1] === 'string' && (config.document && config.document.permissions && config.document.permissions.edit === false || config.editorConfig && config.editorConfig.mode == 'view'))
if ((isPdf || oldForm) && (config.document && config.document.permissions && config.document.permissions.edit === false || config.editorConfig && config.editorConfig.mode == 'view'))
params += "&mode=fillforms";

if (config.document) {
config.document.isForm = (type && typeof type[1] === 'string') ? config.document.isForm : false;
config.document.isForm = isPdf ? config.document.isForm : oldForm;
(config.document.isForm===true || config.document.isForm===false) && (params += "&isForm=" + config.document.isForm);
}

Expand Down
3 changes: 3 additions & 0 deletions apps/documenteditor/embed/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -251,6 +251,9 @@
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
<h4 id="id-critical-error-title"></h4>
</div>
<div class="modal-body">
Expand Down
3 changes: 3 additions & 0 deletions apps/documenteditor/embed/index.html.deploy
Original file line number Diff line number Diff line change
Expand Up @@ -242,6 +242,9 @@
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
<h4 id="id-critical-error-title"></h4>
</div>
<div class="modal-body">
Expand Down
3 changes: 3 additions & 0 deletions apps/documenteditor/embed/index_loader.html
Original file line number Diff line number Diff line change
Expand Up @@ -312,6 +312,9 @@
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
<h4 id="id-critical-error-title"></h4>
</div>
<div class="modal-body">
Expand Down
3 changes: 3 additions & 0 deletions apps/documenteditor/embed/index_loader.html.deploy
Original file line number Diff line number Diff line change
Expand Up @@ -304,6 +304,9 @@
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
<h4 id="id-critical-error-title"></h4>
</div>
<div class="modal-body">
Expand Down
27 changes: 25 additions & 2 deletions apps/documenteditor/embed/js/ApplicationController.js
Original file line number Diff line number Diff line change
Expand Up @@ -424,8 +424,12 @@ DE.ApplicationController = new(function(){

if ( !appOptions.canFillForms || permissions.download === false) {
$('#idt-download-docx').hide();
itemsCount --;
}

if ( !appOptions.canFillForms && !appOptions.isOForm || permissions.download === false) {
$('#idt-download-pdf').hide();
itemsCount -= 2;
itemsCount --;
}

if ( !embedConfig.shareUrl || appOptions.canFillForms) {
Expand Down Expand Up @@ -627,6 +631,17 @@ DE.ApplicationController = new(function(){
}, 2000);
}
});

if (appOptions.isOForm && permissions.download!==false) {
$('#id-critical-error-title').text(me.notcriticalErrorTitle);
$('#id-critical-error-message').html(me.textConvertFormDownload);
$('#id-critical-error-close').text(me.textDownloadPdf).off().on('click', function(){
downloadAs(Asc.c_oAscFileType.PDF);
$('#id-critical-error-dialog').modal('hide');
});
$('#id-critical-error-dialog').modal('show');
}

Common.Gateway.documentReady();
Common.Analytics.trackEvent('Load', 'Complete');
}
Expand All @@ -638,6 +653,7 @@ DE.ApplicationController = new(function(){
$('#id-critical-error-title').text(Asc.c_oLicenseResult.NotBefore === licType ? me.titleLicenseNotActive : me.titleLicenseExp);
$('#id-critical-error-message').html(Asc.c_oLicenseResult.NotBefore === licType ? me.warnLicenseBefore : me.warnLicenseExp);
$('#id-critical-error-close').parent().remove();
$('#id-critical-error-dialog button.close').remove();
$('#id-critical-error-dialog').css('z-index', 20002).modal({backdrop: 'static', keyboard: false, show: true});
return;
}
Expand All @@ -648,6 +664,9 @@ DE.ApplicationController = new(function(){
appOptions.canBranding = params.asc_getCustomization();
appOptions.canBranding && setBranding(config.customization);

var type = /^(?:(docxf|oform))$/.exec(docConfig.fileType);
appOptions.isOForm = !!(type && typeof type[1] === 'string'); // oform and docxf

api.asc_setViewMode(!appOptions.canFillForms);

btnSubmit = $('#id-btn-submit');
Expand Down Expand Up @@ -736,6 +755,7 @@ DE.ApplicationController = new(function(){
$('#id-critical-error-close').text(me.txtClose).off().on('click', function(){
window.location.reload();
});
$('#id-critical-error-dialog button.close').remove();
$('#id-critical-error-dialog').css('z-index', 20002).modal('show');
return;
}
Expand Down Expand Up @@ -841,6 +861,7 @@ DE.ApplicationController = new(function(){
$('#id-critical-error-close').text(me.txtClose).off().on('click', function(){
window.location.reload();
});
$('#id-critical-error-dialog button.close').remove();
}
else {
Common.Gateway.reportWarning(id, message);
Expand Down Expand Up @@ -1060,6 +1081,8 @@ DE.ApplicationController = new(function(){
titleLicenseExp: 'License expired',
titleLicenseNotActive: 'License not active',
warnLicenseBefore: 'License not active. Please contact your administrator.',
warnLicenseExp: 'Your license has expired. Please update your license and refresh the page.'
warnLicenseExp: 'Your license has expired. Please update your license and refresh the page.',
textConvertFormDownload: 'Download file as a fillable PDF form to be able to fill it out.',
textDownloadPdf: 'Download pdf'
}
})();
2 changes: 2 additions & 0 deletions apps/documenteditor/embed/locale/en.json
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,8 @@
"DE.ApplicationController.waitText": "Please, wait...",
"DE.ApplicationController.warnLicenseBefore": "License not active. Please contact your administrator.",
"DE.ApplicationController.warnLicenseExp": "Your license has expired. Please update your license and refresh the page.",
"DE.ApplicationController.textConvertFormDownload": "Download file as a fillable PDF form to be able to fill it out.",
"DE.ApplicationController.textDownloadPdf": "Download PDF",
"DE.ApplicationView.txtDownload": "Download",
"DE.ApplicationView.txtDownloadDocx": "Download as DOCX",
"DE.ApplicationView.txtDownloadPdf": "Download as PDF",
Expand Down
4 changes: 1 addition & 3 deletions apps/documenteditor/main/app/controller/Main.js
Original file line number Diff line number Diff line change
Expand Up @@ -573,9 +573,7 @@ define([

var type = data.doc ? /^(?:(docxf|oform)|(pdf))$/.exec(data.doc.fileType) : false;
this.appOptions.isFormCreator = !!(type && (typeof type[1] === 'string' || typeof type[2] === 'string' && this.appOptions.isPDFForm)) && this.appOptions.canFeatureForms; // show forms only for docxf or oform

type = data.doc ? /^(?:(oform))$/.exec(data.doc.fileType) : false;
this.appOptions.isOForm = !!(type && typeof type[1] === 'string');
this.appOptions.isOForm = !!(type && typeof type[1] === 'string'); // oform and docxf

this.api.asc_registerCallback('asc_onGetEditorPermissions', _.bind(this.onEditorPermissions, this));
this.api.asc_registerCallback('asc_onLicenseChanged', _.bind(this.onLicenseChanged, this));
Expand Down
2 changes: 1 addition & 1 deletion apps/documenteditor/main/app/controller/Toolbar.js
Original file line number Diff line number Diff line change
Expand Up @@ -3654,7 +3654,7 @@ define([
}
}

config.isOForm && config.canDownloadForms && Common.UI.warning({
config.isOForm && config.canDownload && Common.UI.warning({
msg : config.canRequestSaveAs || !!config.saveAsUrl || config.isOffline ? me.textConvertFormSave : me.textConvertFormDownload,
buttons: [{value: 'ok', caption: config.canRequestSaveAs || !!config.saveAsUrl || config.isOffline ? me.textSavePdf : me.textDownloadPdf}, 'cancel'],
callback: function(btn){
Expand Down

0 comments on commit 1e16c5c

Please sign in to comment.