ShowModaldialog dall'app di SharePoint Hosted non funziona
-
10-12-2019 - |
Domanda
Sto avendo lo stesso problema come in più altre discussioni:
Chrome :
Cannot read property 'defaultDialogWidth' of undefined
Firefox : SP.Res is undefined
https://sharepoint.stackexchange.com/posts/76044 http://social.mssdn.microsoft.com/forums/sharepoint/en-us/bf1dc5ea-c045-48f6-b0cd-144d0ab7c1ce/spreshesndenbuttonValuebeforedialog-is-nul-or-not- un oggetto? Forum= SharePointDevelopmentPrevious http://chuvash.eu/2012/02/13/sscripstresx -Shx-in-SharePoint /
Ho provato varie soluzioni pubblicate online ma nessuno sembra funzionare. Qualcuno può dirmi quali dipendenze mi mancano? (Non sto usando una masterpage)
Ho il seguente codice:
.
function showTimeSheetLinesDialog(guid) {
var options = {};
options.width = 500;
options.height = 640;
//options.url = getQueryStringParameter('SPAppWebUrl') + '/Pages/TimeSheetLineDetail.aspx?guid=' + guid + '&json=' + $("#" + guid).attr('data-lines');
options.title = 'Dialog title';
options.allowMaximize = false;
options.showClose = true;
//SP.UI.ModalDialog.showModalDialog(options);
ExecuteOrDelayUntilScriptLoaded(SP.SOD.execute('sp.ui.dialog.js', 'SP.UI.ModalDialog.showModalDialog', options), "SP.js")
//SP.SOD.execute('sp.ui.dialog.js', 'SP.UI.ModalDialog.showModalDialog', options);
// parent.SP.SOD.execute('sp.ui.dialog.js', 'SP.UI.ModalDialog.showModalDialog', options);
}
e i seguenti script caricati:
. <head>
<base target="_parent" />
<title></title>
<script type="text/javascript" src="/_layouts/15/init.js"></script>
<script type="text/javascript" src="../Scripts/jquery-1.8.2.min.js"></script>
<script type="text/javascript" src="/_layouts/15/MicrosoftAjax.js"></script>
<script type="text/javascript" src="/_layouts/15/sp.runtime.debug.js"></script>
<script type="text/javascript" src="/_layouts/15/sp.debug.js"></script>
<script type="text/javascript" src="/_layouts/15/ps.debug.js"></script>
<script type="text/javascript" src="/_layouts/15/sp.ui.dialog.js"></script>
<script type="text/javascript" src="../Scripts/moment.js"></script>
<script type="text/javascript" src="/_layouts/15/sp.init.js"></script>
<script src="/_layouts/15/ScriptResx.ashx?culture=nb-no&name=SP.Res"></script>
<link href="../Content/bootstrap.min.css" rel="stylesheet">
<link href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap-glyphicons.css" rel="stylesheet">
<script src="../Scripts/bootstrap.min.js"></script>
<script src="../Scripts/Warning.js"></script>
</head>
Soluzione
Alla fine ho trovato le dipendenze mancanti, in caso chiunque si imbatti in lo stesso problema, sono i seguenti:
<script type="text/javascript" src="/_layouts/15/ScriptResx.ashx?culture=en%2Dus&name=SP%2ERes"></script>
<script type="text/javascript">
'use strict';
// Set the style of the client web part page to be consistent with the host web.
(function () {
var hostUrl = '';
if (document.URL.indexOf('?') != -1) {
var params = document.URL.split('?')[1].split('&');
for (var i = 0; i < params.length; i++) {
var p = decodeURIComponent(params[i]);
if (/^SPHostUrl=/i.test(p)) {
hostUrl = p.split('=')[1];
document.write('<link rel="stylesheet" href="' + hostUrl + '/_layouts/15/defaultcss.ashx" />');
break;
}
}
}
if (hostUrl == '') {
document.write('<link rel="stylesheet" href="/_layouts/15/1033/styles/themable/corev15.css" />');
}
})();
.
Altri suggerimenti
Hai controllato questo link?
menziona questo:
.La pagina Web che ospita la tua app deve avere quanto segue:
<WebPartPages:AllowFraming ID="AllowFraming1" runat="server" />
Aggiungi _ribbon = new Object();
dopo lo script sp.ui.dialog.js
caricato.
Esempio:
<script type="text/javascript" src="/_layouts/15/sp.ui.dialog.js"></script>
<script type="text/javascript">
_ribbon = new Object();
</script>
.