ShowModaldialog de la aplicación alojada SharePoint no funciona
-
10-12-2019 - |
Pregunta
Estoy teniendo el mismo problema como en múltiples otras discusiones:
cromo :
Cannot read property 'defaultDialogWidth' of undefined
Firefox : SP.Res is undefined
https://sharepoint.stackexchange.com/posts/76044 http://social.msdn.microsoft.com/forums/sharepoint/en-us/bf1dc5e-c045-48f6-b0cd-144d0ab7c1ce/spreshiddenbuttonvalueforedialog-is-null-or-not- un objeto? Forum= SharePointDevelopmentPrevious http://chuvash.eu/2012/02/13/scriptresx -ashx-in-sharepoint /
He probado varias soluciones publicadas en línea, pero ninguna parece funcionar. ¿Alguien puede decirme qué dependencias me estoy perdiendo? (No estoy usando una maestría)
Tengo el siguiente código:
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);
}
y los siguientes scripts cargados:
<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>
Solución
Eventualmente encontré las dependencias que faltan, en caso de que cualquiera se ejecute en el mismo problema, son las siguientes:
<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" />');
}
})();
Otros consejos
¿Has revisado este enlace?
Menciona esto:
La página web que aloja su aplicación debe tener lo siguiente:
<WebPartPages:AllowFraming ID="AllowFraming1" runat="server" />
Añadir _ribbon = new Object();
después de la script de sp.ui.dialog.js
cargado.
Ejemplo:
<script type="text/javascript" src="/_layouts/15/sp.ui.dialog.js"></script>
<script type="text/javascript">
_ribbon = new Object();
</script>