2017-03-31 1 views
0

J'essaie de créer un complément sur le mode composer pour Outlook dans mac, et quand j'insère du HTML dans l'élément body, J'ai remarqué qu'il n'y a pas de propriétés attachées.Outlook pour mac (add-in) - le corps ne conserve pas les propriétés html lorsqu'il est créé avec setSelectedDataAsync

Exemple (simplifié aux fins d'explication):

var contents = "<br/> <a id=\"myelement" + MyElement+ "\" href=\"dev.office.com\"></a>"; 
Office.context.mailbox.item.body.setSelectedDataAsync(contents, { coercionType: "html" }); 

devient:

<br/> 
<a href="dev.office.com" style="color: rgb(5, 99, 193); text-decoration: underline;">MyElement</a> 

Il n'y a pas id sur ci-dessus et un nouveau style est appliqué. (Notez que je peux le voir en enregistrant l'e-mail comme brouillon puis en l'inspectant sur Office 365)

Répondre

0

setSelectedDataAsync() la modification du code HTML est un bug qui a été signalé à l'équipe concernée. Cela doit être fixé dès que possible.

En attendant de vérifier si l'hôte est une perspective Mac, vous pouvez utiliser la vérification API suivante office.context.platform

si l'API ci-dessus ne fonctionne pas (comme toujours d'être poussé à la production et non accessible à tous utilisateurs), vous pouvez analyser l'agent utilisateur pour vérifier le type de plate-forme. exemple de code

var 
    ua = navigator.userAgent, 
    browser = /Edge\/\d+/.test(ua) ? 'ed' : /MSIE 9/.test(ua) ? 'ie9' : /MSIE 10/.test(ua) ? 'ie10' : /MSIE 11/.test(ua) ? 'ie11' : /MSIE\s\d/.test(ua) ? 'ie?' : /rv\:11/.test(ua) ? 'ie11' : /Firefox\W\d/.test(ua) ? 'ff' : /Chrome\W\d/.test(ua) ? 'gc' : /Chromium\W\d/.test(ua) ? 'oc' : /\bSafari\W\d/.test(ua) ? 'sa' : /\bOpera\W\d/.test(ua) ? 'op' : /\bOPR\W\d/i.test(ua) ? 'op' : typeof MSPointerEvent !== 'undefined' ? 'ie?' : '', 
    os = /Windows NT 10/.test(ua) ? "win10" : /Windows NT 6\.0/.test(ua) ? "winvista" : /Windows NT 6\.1/.test(ua) ? "win7" : /Windows NT 6\.\d/.test(ua) ? "win8" : /Windows NT 5\.1/.test(ua) ? "winxp" : /Windows NT [1-5]\./.test(ua) ? "winnt" : /Mac/.test(ua) ? "mac" : /Linux/.test(ua) ? "linux" : /X11/.test(ua) ? "nix" : "", 
    mobile = /IEMobile|Windows Phone|Lumia/i.test(ua) ? 'w' : /iPhone|iP[oa]d/.test(ua) ? 'i' : /Android/.test(ua) ? 'a' : /BlackBerry|PlayBook|BB10/.test(ua) ? 'b' : /Mobile Safari/.test(ua) ? 's' : /webOS|Mobile|Tablet|Opera Mini|\bCrMo\/|Opera Mobi/i.test(ua) ? 1 : 0, 
    tablet = /Tablet|iPad/i.test(ua), 
    touch = 'ontouchstart' in document.documentElement 
+0

Quelle est la question? –

+0

@JordanDavis, la section de vérification de la plate-forme a été donnée afin qu'il puisse y avoir un traitement HTML spécifique si c'est un scénario mac outlook –