Фильтры

В IDS Borjomi открыта вакансия Разработчика Terrasoft

Локация: Москва или удаленный формат работы
 

Основные задачи:

✅ Разработка на платформе Creatio (Terrasoft)

✅ Оценка сроков выполнения

✅ Оптимизация и настройка текущего функционала

✅ Диагностика и устранение ошибок на уровне кода

✅ Консультации и обучение пользователей

✅ Кастомизация встроенных решений Sales, Marketing

 

Мы ожидаем:

✅Опыт работы в роли разработчика на платформе Creatio (Terrasoft) от 1 года

✅Знание платформы Creatio (Terrasoft)

✅Знание JavaScript

✅Знание C#

✅Желательно знание SQL, T-SQL (или опыт работы с PostgreSQL или Oracle) на уровне написания сложных запросов, представлений и процедур

✅Умение работать с чужим кодом

✅Опыт работы с Git желателен

✅Настройка интеграции c внешними сервисами

 

Контактное лицо

Анна
Mob.: 8 (906) 098 3145

E-mail: a.mosinyan@ids-borjomi.com 

 

Нравится

Поделиться

0 комментариев
Показать все комментарии

Новый проект от «Газпром нефть» по доработке и развитию системы на платформе Terrasoft Creatio.

 

Приглашаем специалистов по 3 ролям:

 

Длительность проекта: 2 месяца

Вознаграждение: 275 200 – 400 000 за проект

 

Основные задачи Технического лидера:

Проанализировать набор веток в Git и при необходимости реорганизовать его

Выполнять слияние (merge) веток подпроектов с основными ветками

Реорганизовать процесс сборки пакетов поставки, предложить варианты автоматизации

Выявлять узкие и слабые места в конфигурации, предлагать варианты их устранения

 

Основные задачи Разработчиков:

Реализовать/доработать требуемый функционал, проверить его работоспособность на своей сборке, при необходимости привлечь аналитика

Произвести коммит в Git, при необходимости доработать код по замечаниям технического лидера

По результатам тестирования, при наличии замечаний доработать код

 

 

Мы ожидаем:

Опыт разработки на Terrasoft Creatio на позиции уровня middle/middle+ не менее 2 лет

☝️ Знание технологий:

  • Advanced JavaScript
  • Advanced C#, NET Core
  • PostgreSQL
  • Git

Глубокое знание архитектуры Terrasoft Creatio, базового функционала платформы

 

Детальное описание проекта: https://clck.ru/XXJh2

 

Контактное лицо:
Катерина Неделина

nedelina.es@gazprom-neft.ru

8 921 384 99 59

Нравится

Поделиться

0 комментариев
Показать все комментарии

Подписаться на сообщение загрузки модуля из схемы EmailMessagePublisherPage

messages: {
			"SendListenerEmailData": {
				mode: this.Terrasoft.MessageMode.PTP,
				direction: this.Terrasoft.MessageDirectionType.PUBLISH
			},
			"EmailMessagePageLoaded": {
				mode: this.Terrasoft.MessageMode.PTP,
				direction: this.Terrasoft.MessageDirectionType.SUBSCRIBE
			},
		},
		methods: {
			init: function(){
				this.callParent(arguments);
				this.sandbox.subscribe("EmailMessagePageLoaded", this.onEmailMessagePageLoaded, this, [this.getEmailMessagePublisherModuleId()]);
			},
 
			onEmailMessagePageLoaded: function(args){
				debugger;
				if (this.$EntitySchemaName === "NrbCase") {
					Terrasoft.chain(
						function (next) {
							var esq = Ext.create("Terrasoft.EntitySchemaQuery", { rootSchemaName: "NrbConfigurator", rowCount: 1 });
							esq.addColumn("NrbMailboxForComunicationWithClient");
							esq.getEntityCollection(function (result) {
								if (!result.success || result.collection.count == 0) {
									throw new Error("Запись конфигуратора не найдена");
								}
								var getMailFromConfigurator = result.collection.first();
								var senderEmailConfigurator = getMailFromConfigurator.values.NrbMailboxForComunicationWithClient;
								next(senderEmailConfigurator);
							}, this);
						},
						function (next, senderEmailConfigurator) {
							data = {
								entitySchemaName: this.$EntitySchemaName,
								title: this.getMasterEntityParameterValue("Number"),
								recepientEmail: this.getMasterEntityParameterValue("NrbContactEmail"),
								contact: this.getMasterEntityParameterValue("Contact"),
								nrbObject: this.getMasterEntityParameterValue("NrbServiceObject"),
								senderEmail: senderEmailConfigurator
							}
							this.sandbox.publish("SendListenerEmailData", data, [this.getEmailMessagePublisherModuleId()]);
						}, this
					);
				}
			},

И опубликовать сообщение SendListenerEmailData

Переопределить схему EmailMessagePublisherPage

define("EmailMessagePublisherPage", ["EmailMessagePublisherPageResources"],
		function(resources) {
			return {
				entitySchemaName: "Activity",
				mixins: {
				},
				messages: {},
				attributes: {},
				methods: {
                  	setListenerEmailData: function(data) {
                      	this.callParent(arguments);
                      	debugger;
                        if(data.entitySchemaName == "NrbCase"){
							this.$Title = data.title;
                          	this.$Recepient = data.recepientEmail;
                          	this.$NrbObject = data.nrbObject.value || {};
                          	this.$Sender = data.senderEmail;
                          	this.$Contact = data.contact;
 
                        }
					},
                },
				diff: /**SCHEMA_DIFF*/[]/**SCHEMA_DIFF*/
			};
		});

 

Нравится

Поделиться

0 комментариев
Показать все комментарии

Проект: Расширение функциональности сервиса обратной связи на платформе Terrasoft Service Creatio

https://clck.ru/XL4tn
 

Роль: Разработчик Terrasoft Service Creatio

Компания: Газпром нефть

Вознаграждение: 300 000 

Формат работы: гибридный

Длительность проекта: 2 месяца

 

Проект срочный - сбор откликов до 10.09!

 

Компания «Газпром нефть» разрабатывает и использует большое число решений, направленных на улучшение условий труда сотрудников. Одно из таких решений —система для организации внутренних коммуникаций, а также сбора и анализа обратной связи от сотрудников компании, сокращенно называемая СРОС. Она реализуется с помощью решения Terrasoft Creatio Service Enterprise on-site и по сути представляет собой омниканальную систему для обработки обращений, хранения и анализа результатов исследований и опросов сотрудников.

 

Мы ожидаем:

Опыт разработки крупных, масштабируемых решений

☝️ Знание технологий:

  • Advanced JavaScript
  • Advanced C#
  • NET Core
  • Advanced MS SQL
  • PostgreSQL
  • Git
  • Jenkins
  • Terrasoft Creation BPM

Анализ планов выполнения запросов и их оптимизация MVVM

 

Основные задачи:

Создание и развитие программных продуктов линейки bpm’online

Анализ существующих решений задачи, проработка и детальное описание решения задачи, участие в утверждении архитектуры

Обеспечение качества продукта - помощь в тестировании разработанного функционала, участие в разработке тестового фреймворка, обеспечение и контроль стабильности тестов, реализация автоматизированных acceptance и unit тестов

 

Проект размещен на платформе «Профессионалы 4.0» - зарегистрируйтесь и заполните профиль, чтобы откликнуться на проект.

Прямая ссылка для отклика на роль: https://clck.ru/XL4tn

 

Контактное лицо:

Катерина Неделина

Nedelina.es@gazprom-neft.ru  

Нравится

Поделиться

0 комментариев
Показать все комментарии
using System;
using System.Collections.Generic;
using Terrasoft.Core;
using Terrasoft.Core.DB;
using Terrasoft.Core.Entities;
 
namespace Norbit.Crm.EsPlus.Common
{
    /// <summary>
    /// Методы расширения для ESQ.
    /// </summary>
    public static class EsqExtensions
    {
        /// <summary>
        /// Постраничное чтение ESQ запроса.
        /// </summary>
        /// <param name="esq">Запрос.</param>
        /// <param name="userConnection">Пользовательское подключение.</param>
        /// <param name="rowCount">Количество считываемых записей за один раз(по умолчанию 1000).</param>
        /// <returns>Коллекция объектов из запроса.</returns>
        public static List<Entity> GetEntityCollectionPaginatedReading(
            this EntitySchemaQuery esq,
            UserConnection userConnection,
            EntitySchemaQueryOptions options = null,
            int rowCount = 1000)
        {
            if (esq == null)
            {
                throw new ArgumentNullException(nameof(esq));
            }
 
            if (userConnection == null)
            {
                throw new ArgumentNullException(nameof(userConnection));
            }
 
            var entityCollection = new List<Entity>();
            esq.UseOffsetFetchPaging = true;                              /// Использовать постраничное чтение.
 
            var esqOptions = options ?? new EntitySchemaQueryOptions                     /// Настройки получения коллекции.
            {
                PageableRowCount = rowCount,                             /// Количество считываемых записей.
                RowsOffset = 0,                                          /// Количество записей, которые необходимо пропустить
                PageableDirection = PageableSelectDirection.Next,
                PageableConditionValues = new Dictionary<string, object>()
            };
 
            var entities = esq.GetEntityCollection(userConnection, esqOptions);
 
            while (entities.Count > 0)
            {
                foreach (var entity in entities)
                {
                    entityCollection.Add(entity);
                }
                esqOptions.RowsOffset += esqOptions.PageableRowCount;
                esq.ResetSelectQuery();                                     /// Обнуление результата запроса.
                entities = esq.GetEntityCollection(userConnection, esqOptions);
            }
 
            return entityCollection;
        }
 
    }
}

 

Нравится

Поделиться

1 комментарий

Есть подозрение. что поможет 
PageableDirection = PageableSelectDirection.First  при первом запросе.
потом сменить на Next

Показать все комментарии