SharePoint-hosted app Alexander Krupsky Artur Kukharevich Содержание. • Вариант SharePoint-hosted app • Проблемы • Шаблоны сайтов • Cross-domain calls • Localization • Выводы 2 Вариант SharePoint-hosted app Запрос на отпуск. Необходимо: 1. Реализовать простой процесс 2. Вывести данные на временную линию 3. Возможность создания заявки должна быть на любой странице сайта Проблемы. Права Установка прав на элемент списка - Workflow не поддерживает (не актуально) - Нет Event Receiver - Переопределение момента сохранения через JS не возможно при наличии прикрепленных файлов Проблемы. Права Фиг с ним с элементом. Как установить изначальные права на сайте app и установить изначальные настройки? Что говорит по этому поводу MSDN: In some cases, the app will require certain information or choices to be provided before the app can function. When your app requires information before it can function, you should provide a user experience that guides the user to the settings page to update the configuration. You should add the settings page URL to the app’s top-right menu if appropriate so that users can find it easily. If your app has a getting started experience or other settings, you can add those also. For more information, see How to: Use the client chrome control in apps for SharePoint. Проблемы. Календарь Я хочу чтобы у меня отпуск был каждый месяц по два дня, выпадающих на первую неделю в течении двух лет. Если список находится не на сайте app, то сочувствую, т к SharePoint API позволяет сделать повторяющиеся события: 1. Серверный код 2. Запрос к сервису с установкой Date Overlap Проблемы. Client Web Parts Ограничения: • Встраивается на страницу при помощи iFrame • Фиксированный размер Проблемы. Client Web Parts Изменения размера iframe var resizeMessage = '<message senderId={Sender_ID}>resize({Width}, {Height})</message>'; resizeMessage = resizeMessage.replace("{Sender_ID}", senderId); resizeMessage = resizeMessage.replace("{Height}", newHeight); resizeMessage = resizeMessage.replace("{Width}", newWidth); window.parent.postMessage(resizeMessage, "*"); Где SenderId – параметр, который берется с query string. Важно!!! Этот метод работает, когда для Client Web Part задана автоматическая ширина и(или) высота. Проблемы. Workflow Скрытые активности Как локализовать workflow? Шаблоны сайтов Возможно, но используйте с умом, а лучше вообще не используйте) Что говорит по этому поводу MSDN: Do not use the WebTemplate element in the app manifest to designate any of the built-in SharePoint site definition configurations as the app web's site type. We do not support using any of the built-in site definition configurations, other than APP#0, for app webs. Cross-domain calls Using REST (работает через AppWebProxy.aspx): $.getScript(scriptbase + "SP.RequestExecutor.js", execCrossDomainRequest); function execCrossDomainRequest() { var executor; executor = new SP.RequestExecutor(appweburl); executor.executeAsync( { url: appweburl + "/_api/SP.AppContextSite(@target)/web/title?@target='" + hostweburl + "'", method: "GET", headers: { "Accept": "application/json; odata=verbose" }, success: successHandler, error: errorHandler } ); } Cross-domain calls. Architecture Cross-domain calls Using REST (не использует AppWebProxy.aspx): var context = new SP.ClientContext(_appweburl); var factory = new SP.ProxyWebRequestExecutorFactory(_appweburl); context.set_webRequestExecutorFactory(factory); var appContextSite = new SP.AppContextSite(context, _hostweburl); // наш запрос context.executeQueryAsync(); Пример запроса: <Request xmlns="http://schemas.microsoft.com/sharepoint/clientquery/2009" SchemaVersion="15.0.0.0" LibraryVersion="16.0.0.0" ApplicationName="Javascript Library"> <Actions> <ObjectPath Id="69" ObjectPathId="68" /> </Actions> <ObjectPaths> <Constructor Id="68" TypeId="{5530f782-6a0d-41ec-bfd9-2cb628fe1557}"> <Parameters> <Parameter Type="String">https://spsitepro.sharepoint.com/sites/apps</Parameter> </Parameters> </Constructor> </ObjectPaths> </Request> Localization. С чего начать А начинается все безобидно) В настройках AppManifest указываем поддерживаемые языки и Visual Studio автоматически сгенерирует необходимые ресурсные файлы. Localization. В контексте App Web Для локализации модулей(Lists, ContentTypes и т.п.), которые будут доступны только на App Web необходимо использовать стандартную конструкцию: $Resources:Resource_key; Localization. В контексте Hosted-Web Может применяться для локализации App Client Web Part, Ribbon Actions. Используем: $Resources:Resource_key; Получаем: Localization. В контексте Hosted-Web Вот так Microsoft описывает проблему: To add OPC relationship markup to the app package 1. Append a .zip extension to the app package. 2. In the .zip file, open the folder named _rels. 3. Open the AppManifest.xml.rels file. This file specifies the OPC relationships of the AppManifest.xml file to other files in the package. The file contains a Relationship element for the Resources.resx file and for each of the Resources.LL-CC.resx files. The following are examples: <Relationship Type="http://schemas.microsoft.com/sharepoint/2012/app/relationships/content-defaultresource" Target="/Resources.resx" Id="R8d5c4429fc13446e" /> <Relationship Type="http://schemas.microsoft.com/sharepoint/2012/app/relationships/content-resource" Target="/Resources.en-US.resx" Id="R71986f3a45e24d8f" /> 4. 5. 6. 7. 8. 9. Copy these resource-related Relationship elements and save them in a text file outside the package so you can reuse them in a later step. Close the AppManifest.xml.rels file. In the _rels folder, open the featureGUID.xml.rels file. This file specifies the OPC relationships of the featureGUID.xml file and all its child files, such as elements.xml files, to other files in the package. Paste into the Relationships element all of the Relationship elements that you copied from the AppManifest.xml.rels file. It’s OK to use the same relationship IDs because you are pasting them into a different parent Relationships element. Save (as UTF-8) and close the file. Close the .zip file and then remove the ".zip" from the end of the file name. The app package can now be installed on your test SharePoint website. Localization. В контексте Hosted-Web Скачать с Msdn утилиту AddRelsToAppPackage (http://msdn.microsoft.com/en-us/library/fp179919.aspx) СПОСОБ РАБОТАЕТ ТОЛЬКО ПРИ Deploy!!!!! Localization. В контексте Hosted-Web Сделаем, что бы работало при deploy и publish. В .csproj файл добавить следующее: <Target Name="ConfigureResourses" AfterTargets="PackageSharePointApp"> <Exec Command="$(SolutionDir)ConfigureRelsToAppPackage.exe $(TargetDir)" ContinueOnError="false"></Exec> </Target> после строки: <Import Project="$(VSToolsPath)\SharePointTools\Microsoft.VisualStudio.SharePoint.targets" Condition="'$(VSToolsPath)' != ''" /> Localization. UI А как же быть с alert и ему подобным??? Выводы А выводы делайте сами ;)