Commit 3d069d6c authored by Olessya Khussainova's avatar Olessya Khussainova

buildin objects addon

parent 243886c4
......@@ -61,6 +61,7 @@ crm/spec/resources/img/add_notification.png -text
crm/spec/resources/img/canban.png -text
crm/spec/resources/img/canban_2.png -text
crm/spec/resources/img/connections.png -text
crm/spec/resources/img/crm.png -text
crm/spec/resources/img/crm_icon.png -text
crm/spec/resources/img/dfd.png -text
crm/spec/resources/img/eventChooser.png -text
......@@ -77,6 +78,7 @@ crm/spec/resources/img/user_button.png -text
crm/spec/src/about.md -text
crm/spec/src/crm_common.md -text
crm/spec/src/crm_consist/buildin_objects.md -text
crm/spec/src/crm_consist/buildin_objects_user_modules.md -text
crm/spec/src/crm_consist/index.md -text
crm/spec/src/crm_consist/marketing.md -text
crm/spec/src/crm_consist/marketing_cost_comission.md -text
......
......@@ -2,10 +2,16 @@
Конфигурация Synergy CRM включает в себя встроенные объекты:
- Группы пользователей:
- Все маркетологи
- Маркетологи-менеджеры
- Маркетологи-специалисты
* Группы пользователей:
* Все маркетологи
* Маркетологи-менеджеры
* Маркетологи-специалисты
* [Счетчики](#crm2.counters):
* [Счетчик каталога товаров и услуг](#crm2.countersCatalog)
* [Шаблоны номеров](#crm2.pattern_number):
* [Номер товара в каталоге](#crm2.pattern_number_Catalog)
* [Формы](#crm2.forms):
* [Маркетинговое мероприятие](#crm2.formEvent)
......@@ -17,16 +23,23 @@
* [Тема сотрудничества](#crm2.formTheme)
* [Товар (услуга)](#crm2.formItem)
* [Цена](#crm2.formPrice)
- [Договор поставки (единовременная оплата)](#crm8.formContractDeliveryAll)
- [Договор поставки (оплата частями)](#crm8.formContractDeliveryPart)
- [Коммерческое предложение](#crm8.formOffer)
- [Акт приема-передачи товара](#crm8.formCertificate)
* [Счетчики](#crm2.counters):
* [Счетчик каталога товаров и услуг](#crm2.countersCatalog)
* [Шаблоны номеров](#crm2.pattern_number):
* [Номер товара в каталоге](#crm2.pattern_number_Catalog)
* [Договор поставки (единовременная оплата)](#crm8.formContractDeliveryAll)
* [Договор поставки (оплата частями)](#crm8.formContractDeliveryPart)
* [Коммерческое предложение](#crm8.formOffer)
* [Акт приема-передачи товара](#crm8.formCertificate)
* [Пользовательские компоненты](#crm2.userModules)
* [crm_component_canban](#crm2.uMCanban)
* [crm_component_deal_button](#crm2.uMDealButton)
* [crm_component_funnel](#crm2.uMFunnel)
* [crm_component_group_button](#crm2.uMGroupButton)
* [crm_component_notifications](#crm2.uMNotifications)
* [crm_component_registry_chooser](#crm2.uMRegistryChooser)
* [crm_component_social_links_accounts](#crm2.uMSocialLinksAccounts)
* [crm_component_social_links_contacts](#crm2.uMSocialLinksContacts)
* [Внешние модули-компоненты](#crm2.externalModules)
* [crm_notifications](#crm2.eMNotifications)
* [Реестры](#crm2.registries):
* [Маркетинговое мероприятие](#crm2.registryEvent)
......@@ -38,10 +51,15 @@
* [Темы сотрудничества](#crm2.registryThemes)
* [Каталог товаров и услуг](#crm2.registryItems)
* [Прайс-лист](#crm2.registryPriceList)
- [Договоры поставки (единовременная оплата)](#crm8.registryContractDeliveryAll)
- [Договоры поставки (оплата частями)](#crm8.registryContractDeliveryPart)
- [Коммерческие предложения](#crm8.registryOffer)
- [Акты приема-передачи товара](#crm8.registryCertificates)
* [Договоры поставки (единовременная оплата)](#crm8.registryContractDeliveryAll)
* [Договоры поставки (оплата частями)](#crm8.registryContractDeliveryPart)
* [Коммерческие предложения](#crm8.registryOffer)
* [Акты приема-передачи товара](#crm8.registryCertificates)
* [Группы реестров](#crm2.registriesGroup)
* [Базовый учет продаж](#crm2.group_marketing)
* [Каталог товаров и услуг](#crm2.group_catalog)
* [Шаблоны документов](#crm2.group_documentTemplates)
* [Справочники](#crm2.dictionaries)
* [Статусы лида](#crm2.dictionaryLeadStatus)
......@@ -57,6 +75,20 @@
* [Действия напоминаний](#crm2.dictionaryremindActions)
* [Города Казахстана](#crm8.dictionaryCities)
* [Создание документов](#crm2.createDoc)
* [Запись аккаунта](#crm2.accountRecord)
* [Запись контакта](#crm2.contacttRecord)
* [Запись лида](#crm2.leadRecord)
* [Запись мероприятия](#crm2.eventRecord)
* [Шаблоны документов](#crm2.docTemplates)
* [Акт приема-передачи](#crm2.certificate)
* [Договор поставки (единовременная оплата)](#crm2.contract100)
* [Договор поставки (оплата частями)](#crm2.contractPart)
* [Коммерческое предложение](#crm2.offer)
* [Внешние модули](#crm2.externalModules)
* [Маркетинг](#crm2.marketing)
### Требования к кодированиию объектов {#crm2.codes}
* Код формы:
......@@ -122,6 +154,40 @@
Пример: crm_dict_leadStatus_name, crm_dict_leadStatus_value
### Счетчики {#crm2.counters}
#### Счетчик каталога товаров и услуг {#crm2.countersCatalog}
Свойства счетчика:
+--------------------------+----------------------------------------+
| Свойство | Значение |
+==========================+========================================+
| Код | crm_counter_catalog |
+--------------------------+----------------------------------------+
| Начальное значение | 1 |
+--------------------------+----------------------------------------+
| Следующее значение | 1 |
+--------------------------+----------------------------------------+
| Период сброса | Никогда |
+--------------------------+----------------------------------------+
### Шаблоны номеров {#crm2.pattern_number}
#### Номер товара в каталоге {#crm2.pattern_number_Catalog}
Свойства шаблона номера:
+--------------------------+----------------------------------------+
| Свойство | Значение |
+==========================+========================================+
| Название | Номер товара в каталоге |
+--------------------------+----------------------------------------+
| Формула | {crm_counter_catalog} |
+--------------------------+----------------------------------------+
| Код | crm_number_catalog |
+--------------------------+----------------------------------------+
### Формы {#crm2.forms}
#### Маркетинговое мероприятие {#crm2.formEvent}
......@@ -139,7 +205,7 @@
+--------------------------------------------------------+---------------------------------------------------------------+--------------------------------------------------------+
| **Стоимость** | числовое поле | crm_form_event_main_cost |
+--------------------------------------------------------+---------------------------------------------------------------+--------------------------------------------------------+
| **Мероприятие** | ссылка | crm_form_event_main_event |
| **Мероприятие** | ссылка на портфель / проект | crm_form_event_main_event |
+--------------------------------------------------------+---------------------------------------------------------------+--------------------------------------------------------+
| **Комментарий** | многострочное поле | crm_form_event_main_comment |
+--------------------------------------------------------+---------------------------------------------------------------+--------------------------------------------------------+
......@@ -1028,39 +1094,23 @@
* включена опция "Не удалять пробелы в начале строки"
### Счетчики {#crm2.counters}
<#include "crm_consist/buildin_objects_user_modules.md">
#### Счетчик каталога товаров и услуг {#crm2.countersCatalog}
### Внешние модули-компоненты {#crm2.externalModules}
Свойства счетчика:
#### crm_notifications {#crm2.eMNotifications}
+--------------------------+----------------------------------------+
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+==========================+========================================+
| Код | crm_counter_catalog |
+--------------------------+----------------------------------------+
| Начальное значение | 1 |
+--------------------------+----------------------------------------+
| Следующее значение | 1 |
+--------------------------+----------------------------------------+
| Период сброса | Никогда |
+--------------------------+----------------------------------------+
### Шаблоны номеров {#crm2.pattern_number}
#### Номер товара в каталоге {#crm2.pattern_number_Catalog}
Свойства шаблона номера:
+--------------------------+----------------------------------------+
| Свойство | Значение |
+==========================+========================================+
| Название | Номер товара в каталоге |
+--------------------------+----------------------------------------+
| Формула | {crm_counter_catalog} |
+--------------------------+----------------------------------------+
| Код | crm_number_catalog |
+--------------------------+----------------------------------------+
+========================================================+==========================================================+
| Код | crm_notifications |
+--------------------------------------------------------+----------------------------------------------------------+
| Место размещения | onLoad |
+--------------------------------------------------------+----------------------------------------------------------+
| Название пользовательского компонента | crm_component_notifications |
+--------------------------------------------------------+----------------------------------------------------------+
| Тип вставки | ADD |
+--------------------------------------------------------+----------------------------------------------------------+
### Реестры {#crm2.registries}
......@@ -1396,7 +1446,6 @@
| crm_form_contract_delivery_100_sum_total | Сумма договора | 5 | нет |
+--------------------------------------------------------+--------------------------------------------------------+----------------------------+---------------------------+
##### Договоры поставки (оплата частями) {#crm8.registryContractDeliveryPart}
Свойства реестра:
......@@ -1497,6 +1546,61 @@
| crm_form_offer_from_user | От кого | 4 | нет |
+--------------------------------------------------------+--------------------------------------------------------+----------------------------+---------------------------+
### Группы реестров {#crm2.registriesGroup}
Конфигурация групп реестров зависит от выбранного
[типа установки CRM](http://tdd.lan.arta.kz/docs/cases/crm/additional/html/basic_setting.html):
При установке типа Clean CRM и Demo CRM:
* [Базовый учет продаж](#crm2.group_marketing)
* [Каталог товаров и услуг](#crm2.group_catalog)
* [Шаблоны документов](#crm2.group_documentTemplates)
При установке типа Install/Upgrade Configuration:
* [Каталог товаров и услуг](#crm2.group_catalog)
* [Шаблоны документов](#crm2.group_documentTemplates)
#### Базовый учёт продаж {#crm2.group_marketing}
Код группы реестров: crm_registryGroup_marketing
Группы:
* [Каталог товаров и услуг](#crm2.group_catalog)
* [Шаблоны документов](#crm2.group_documentTemplates)
Реестры:
* [% комиссии](#crm2.registryComission)
* [Аккаунты](#crm2.registryAccount)
* [Контакты](#crm2.registryContact)
* [Лиды](#crm2.registryLead)
* [Маркетинговые мероприятия](#crm2.registryEvent)
* [Сделки](#crm2.registryDeal)
#### Каталог товаров и услуг {#crm2.group_catalog}
Код группы реестров: crm_registryGroup_catalog
Реестры:
* [Каталог товаров и услуг](#crm2.registryItems)
* [Прайс-лист](#crm2.registryPriceList)
* [Темы сотрудничества](#crm2.registryThemes)
#### Шаблоны документов {#crm2.group_documentTemplates}
Код группы реестров: crm_registryGroup_documentTemplates
Реестры:
* [Акты приема-передачи товара](#crm8.registryCertificates)
* [Договоры поставки (единовременная оплата)](#crm8.registryContractDeliveryAll)
* [Договоры поставки (оплата частями)](#crm8.registryContractDeliveryPart)
* [Коммерческие предложения](#crm8.registryOffer)
### Справочники {#crm2.dictionaries}
#### Статусы лида {#crm2.dictionaryLeadStatus}
......@@ -1968,5 +2072,171 @@
| г. Шымкент | 16 |
+--------------------------------+--------------------------------+
### Создание документов {#crm2.createDoc}
Пункты создания документов представлены следующей структурой:
* [Запись аккаунта](#crm2.accountRecord)
* [Запись контакта](#crm2.contacttRecord)
* [Запись лида](#crm2.leadRecord)
* [Запись мероприятия](#crm2.eventRecord)
* [Шаблоны документов](#crm2.docTemplates)
* [Акт приема-передачи](#crm2.certificate)
* [Договор поставки (единовременная оплата)](#crm2.contract100)
* [Договор поставки (оплата частями)](#crm2.contractPart)
* [Коммерческое предложение](#crm2.offer)
#### Запись аккаунта {#crm2.accountRecord}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Тип | пункт |
+--------------------------------------------------------+----------------------------------------------------------+
| Код | crm_menu_addAccount |
+--------------------------------------------------------+----------------------------------------------------------+
| Реестр | crm_registry_accounts |
+--------------------------------------------------------+----------------------------------------------------------+
| Добавить в "Избранное" пользователя по умолчанию | включен |
+--------------------------------------------------------+----------------------------------------------------------+
| Группа | Все маркетологи |
+--------------------------------------------------------+----------------------------------------------------------+
#### Запись контакта {#crm2.contactRecord}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Тип | пункт |
+--------------------------------------------------------+----------------------------------------------------------+
| Код | crm_menu_addContact |
+--------------------------------------------------------+----------------------------------------------------------+
| Реестр | crm_registry_contacts |
+--------------------------------------------------------+----------------------------------------------------------+
| Добавить в "Избранное" пользователя по умолчанию | включен |
+--------------------------------------------------------+----------------------------------------------------------+
| Группа | Все маркетологи |
+--------------------------------------------------------+----------------------------------------------------------+
#### Запись лида {#crm2.leadRecord}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Тип | пункт |
+--------------------------------------------------------+----------------------------------------------------------+
| Код | crm_menu_addLead |
+--------------------------------------------------------+----------------------------------------------------------+
| Реестр | crm_registry_leads |
+--------------------------------------------------------+----------------------------------------------------------+
| Добавить в "Избранное" пользователя по умолчанию | включен |
+--------------------------------------------------------+----------------------------------------------------------+
| Группа | Все маркетологи |
+--------------------------------------------------------+----------------------------------------------------------+
#### Запись мероприятия {#crm2.eventRecord}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Тип | пункт |
+--------------------------------------------------------+----------------------------------------------------------+
| Код | crm_menu_addEvent |
+--------------------------------------------------------+----------------------------------------------------------+
| Реестр | crm_registry_events |
+--------------------------------------------------------+----------------------------------------------------------+
| Добавить в "Избранное" пользователя по умолчанию | включен |
+--------------------------------------------------------+----------------------------------------------------------+
| Группа | Все маркетологи |
+--------------------------------------------------------+----------------------------------------------------------+
#### Шаблоны документов {#crm2.docTemplates}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Тип | группа |
+--------------------------------------------------------+----------------------------------------------------------+
| Код | crm_menu_addDocuments |
+--------------------------------------------------------+----------------------------------------------------------+
#### Акт приема-передачи {#crm2.certificate}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Тип | пункт |
+--------------------------------------------------------+----------------------------------------------------------+
| Код | crm_menu_addCertificate |
+--------------------------------------------------------+----------------------------------------------------------+
| Реестр | crm_registry_certificates |
+--------------------------------------------------------+----------------------------------------------------------+
| Добавить в "Избранное" пользователя по умолчанию | включен |
+--------------------------------------------------------+----------------------------------------------------------+
| Группа | Все маркетологи |
+--------------------------------------------------------+----------------------------------------------------------+
#### Договор поставки (единовременная оплата) {#crm2.contract100}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Тип | пункт |
+--------------------------------------------------------+----------------------------------------------------------+
| Код | crm_menu_addContract_100 |
+--------------------------------------------------------+----------------------------------------------------------+
| Реестр | crm_registry_contracts_delivery_100 |
+--------------------------------------------------------+----------------------------------------------------------+
| Добавить в "Избранное" пользователя по умолчанию | включен |
+--------------------------------------------------------+----------------------------------------------------------+
| Группа | Все маркетологи |
+--------------------------------------------------------+----------------------------------------------------------+
#### Договор поставки (оплата частями) {#crm2.contractPart}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Тип | пункт |
+--------------------------------------------------------+----------------------------------------------------------+
| Код | crm_menu_addContract_part |
+--------------------------------------------------------+----------------------------------------------------------+
| Реестр | crm_registry_contracts_delivery_part |
+--------------------------------------------------------+----------------------------------------------------------+
| Добавить в "Избранное" пользователя по умолчанию | включен |
+--------------------------------------------------------+----------------------------------------------------------+
| Группа | Все маркетологи |
+--------------------------------------------------------+----------------------------------------------------------+
#### Коммерческое предложение {#crm2.offer}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Тип | пункт |
+--------------------------------------------------------+----------------------------------------------------------+
| Код | crm_menu_addOffer |
+--------------------------------------------------------+----------------------------------------------------------+
| Реестр | crm_registry_offer |
+--------------------------------------------------------+----------------------------------------------------------+
| Добавить в "Избранное" пользователя по умолчанию | включен |
+--------------------------------------------------------+----------------------------------------------------------+
| Группа | Все маркетологи |
+--------------------------------------------------------+----------------------------------------------------------+
### Внешние модули {#crm2.externalModules}
#### Маркетинг {#crm2.marketing}
+--------------------------------------------------------+----------------------------------------------------------------------------------------+
| Свойство | Значение |
+========================================================+========================================================================================+
| Код | crm_extModule |
+--------------------------------------------------------+----------------------------------------------------------------------------------------+
| Адрес приложения | [URL](http://tdd.lan.arta.kz/docs/cases/crm/additional/html/crm_without_data.html)/crm |
+--------------------------------------------------------+----------------------------------------------------------------------------------------+
| Добавить в "Избранное" пользователя по умолчанию | ![](resources/img/crm.png)\ |
+--------------------------------------------------------+----------------------------------------------------------------------------------------+
<#include "crm_consist/user_components.md">
<#include "crm_consist/reminder.md">
### Пользовательские компоненты {#crm2.userModules}
#### crm_component_canban {#crm2.uMCanban}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Код | crm_component_canban |
+--------------------------------------------------------+----------------------------------------------------------+
| Использовать в формах | включен |
+--------------------------------------------------------+----------------------------------------------------------+
HTML код:
``` xml
<div id="redips-drag">
</div>
```
JAVASCRIPT код:
``` xml
/*jslint white: true, browser: true, undef: true, nomen: true, eqeqeq: true, plusplus: false, bitwise: true, regexp: true, strict: true, newcap: true, immed: true, maxerr: 14 */
/*global window: false, REDIPS: true */
/* enable strict mode */
"use strict";
// define redips_init variable
var redipsInit;
// redips initialization
redipsInit = function () {
// reference to the REDIPS.drag library and message line
var rd = REDIPS.drag;
// how to display disabled elements
rd.style.borderDisabled = 'solid'; // border style for disabled element will not be changed (default is dotted)
rd.style.opacityDisabled = 60; // disabled elements will have opacity effect
REDIPS.drag.dropMode = 'multiple';
// initialization
rd.init();
// only "smile" can be placed to the marked cell
rd.mark.exception.d8 = 'smile';
// prepare handlers
rd.event.clicked = function () {
};
rd.event.dblClicked = function () {
};
rd.event.moved = function () {
};
rd.event.notMoved = function () {
};
rd.event.dropped = function () {
var pos = rd.getPosition();
console.log($(rd.obj).attr('status'));
var status = model.currentData[pos[2]];
if ($(rd.obj).attr('status') === status.status) {
return;
}
AS.SERVICES.showWaitWindow();
var pFact = jQuery.ajax({
url: window.location.origin + "/crm/rest/api/funnel/changeLeadStatus?statusID="+(status.status) + "&statusName="+(status.name)+"&leadID=" + rd.obj.id,
type: "POST",
beforeSend: AS.FORMS.ApiUtils.addAuthHeader,
dataType: "text",
error: function(jqXHR, textStatus, errorThrown){
model.playerModel.redraw();
AS.SERVICES.hideWaitWindow();
try {
AS.SERVICES.showErrorMessage(jqXHR.responseText);
} catch (e) {
console.log(e);
}
}
});
jQuery.when(pFact).then(function (data) {
model.playerModel.firstShow = false;
console.log(data);
model.playerModel.redraw();
var object = JSON.parse(data);
if (object.dealObject) {
var documentID = object.id;
var hash = '#' + jQuery.param({
submodule: 'common',
action: 'open_document',
document_identifier: documentID});
window.top.location.hash = hash;
}
AS.SERVICES.hideWaitWindow();
});
};
rd.event.switched = function () {
};
rd.event.clonedEnd1 = function () {
};
rd.event.clonedEnd2 = function () {
};
rd.event.notCloned = function () {
};
rd.event.deleted = function (cloned) {
// if cloned element is directly moved to the trash
if (cloned) {
// set id of original element (read from redips property)
// var id_original = rd.obj.redips.id_original;
}
else {
}
};
rd.event.undeleted = function () {
};
rd.event.cloned = function () {
};
rd.event.changed = function () {
// get target and source position (method returns positions as array)
var pos = rd.getPosition();
};
};
// toggles trash_ask parameter defined at the top
function toggleConfirm(chk) {
if (chk.checked === true) {
REDIPS.drag.trash.question = 'Are you sure you want to delete DIV element?';
}
else {
REDIPS.drag.trash.question = null;
}
}
// toggles delete_cloned parameter defined at the top
function toggleDeleteCloned(chk) {
REDIPS.drag.clone.drop = !chk.checked;
}
// enables / disables dragging
function toggleDragging(chk) {
REDIPS.drag.enableDrag(chk.checked);
}
// function sets drop_option parameter defined at the top
function setMode(radioButton) {
REDIPS.drag.dropMode = radioButton.value;
}
view.initDnd = redipsInit;
```
#### crm_component_deal_button {#crm2.uMDealButton}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Код | crm_component_deal_button |
+--------------------------------------------------------+----------------------------------------------------------+
| Использовать в формах | включен |
+--------------------------------------------------------+----------------------------------------------------------+
HTML код:
``` xml
<button class="ns-approveButton ns-basicChooserApplyButton ui-button ui-widget ui-state-default ui-corner-all ui-button-text-only" role="button" style="margin: 10px 0; display: block;" innerId='make_deal'>Создать</button>
```
JAVASCRIPT код:
``` xml
var button = jQuery(view.container).children("[innerId='make_deal']");
var locale = AS.OPTIONS.locale;
var statusValue;
model.playerModel.dictionaryCache.getDictionary('crm_dict_leadStatus', AS.OPTIONS.locale, function(dictionary) {
if(dictionary !== null) {
dictionary.forEach(function(data, index){
if (data['crm_dict_leadStatus_end'] === '1') {
statusValue = data['crm_dict_leadStatus_value'];
button.text(data['crm_dict_leadStatus_buttonName']);
}
});
}
});
button.click(function(){
model.playerModel.getModelWithId('crm_form_lead_deals_status').setValue(statusValue + '');
});
```
#### crm_component_funnel {#crm2.uMFunnel}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Код | crm_component_funnel |
+--------------------------------------------------------+----------------------------------------------------------+
| Использовать в формах | включен |
+--------------------------------------------------------+----------------------------------------------------------+
HTML код:
``` xml
<style>
.chart {
margin: 0 auto;
margin-top: 20px;
margin-bottom: 20px;
height: 500px;
width: 450px;
}
</style
<!-- Funnel container -->
<div class="chart" id="funnel"></div>
```
JAVASCRIPT код:
``` xml
/* global D3Funnel */
const data = {
normal: [
['Первичная регистрация', [0, ''], '#e73a00'],
['Квалификация', [0, ''], '#fa6c00'],
['Взращивание', [0, ''], '#ffa900'],
['Подтверждение интереса', [0, ''], '#ffc500'],
['В сделку', [0, ''], '#a6cf00'],
]
};
const options = {
chart: {
width: 450,
height: 500,
bottomWidth: 1 / 2,
curve: {
enabled: false,
},
},
block: {
dynamicHeight: true,
highlight: true,
minHeight: 40,
},
label: {
format: '{l}: {v}\n{f}',
},
events: {
click: {
block: (d) => {
alert('<' + d.label.raw + '> selected.');
},
},
}
}
const chart = new D3Funnel('#funnel');
const picker = document.getElementById('picker');
chart.draw(data.normal, options);
```
#### crm_component_group_button {#crm2.uMGroupButton}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Код | crm_component_group_button |
+--------------------------------------------------------+----------------------------------------------------------+
| Использовать в формах | включен |
+--------------------------------------------------------+----------------------------------------------------------+
HTML код:
``` xml
<style>
.btn_boot-group-lg > .btn_boot, .btn_boot-lg {
padding: 10px 16px;
font-size: 18px;
border-radius: 6px
}
.btn_boot-group-sm > .btn_boot, .btn_boot-sm {
padding: 5px 10px;
font-size: 12px;
line-height: 1.5;
border-radius: 3px
}
.btn_boot-group-xs > .btn_boot, .btn_boot-xs {
padding: 1px 5px;
font-size: 12px;
line-height: 1.5;
border-radius: 3px
}
.btn_boot-group, .btn_boot-group-vertical {
position: relative;
vertical-align: middle;
padding-top: 3px;
}
.btn_boot-group-vertical > .btn_boot, .btn_boot-group > .btn_boot {
position: relative;
float: left
}
.btn_boot-group-vertical > .btn_boot.active, .btn_boot-group-vertical > .btn_boot:active, .btn_boot-group-vertical > .btn_boot:focus, .btn_boot-group-vertical > .btn_boot:hover, .btn_boot-group > .btn_boot.active, .btn_boot-group > .btn_boot:active, .btn_boot-group > .btn_boot:focus, .btn_boot-group > .btn_boot:hover {
z-index: 2
}
.btn_boot-group .btn_boot + .btn_boot, .btn_boot-group .btn_boot + .btn_boot-group, .btn_boot-group .btn_boot-group + .btn_boot, .btn_boot-group .btn_boot-group + .btn_boot-group {
margin-left: -1px
}
.btn_boot-toolbar {
margin-left: -5px
}
.btn_boot-toolbar .btn_boot, .btn_boot-toolbar .btn_boot-group, .btn_boot-toolbar .input-group {
float: left
}
.btn_boot-toolbar > .btn_boot, .btn_boot-toolbar > .btn_boot-group, .btn_boot-toolbar > .input-group {
margin-left: 5px
}
.btn_boot-group > .btn_boot:not(:first-child):not(:last-child):not(.dropdown-toggle) {
border-radius: 0
}
.btn_boot-group > .btn_boot:first-child {
margin-left: 0
}
.btn_boot-group > .btn_boot:first-child:not(:last-child):not(.dropdown-toggle) {
border-top-right-radius: 0;
border-bottom-right-radius: 0
}
.btn_boot-group > .btn_boot:last-child:not(:first-child), .btn_boot-group > .dropdown-toggle:not(:first-child) {
border-top-left-radius: 0;
border-bottom-left-radius: 0
}
.btn_boot-group > .btn_boot-group {
float: left
}
.btn_boot-group > .btn_boot-group:not(:first-child):not(:last-child) > .btn_boot {
border-radius: 0
}
.btn_boot-group > .btn_boot-group:first-child:not(:last-child) > .btn_boot:last-child, .btn_boot-group > .btn_boot-group:first-child:not(:last-child) > .dropdown-toggle {
border-top-right-radius: 0;
border-bottom-right-radius: 0
}
.btn_boot-group > .btn_boot-group:last-child:not(:first-child) > .btn_boot:first-child {
border-top-left-radius: 0;
border-bottom-left-radius: 0
}
.btn_boot-group .dropdown-toggle:active, .btn_boot-group.open .dropdown-toggle {
outline: 0
}
.btn_boot-group > .btn_boot + .dropdown-toggle {
padding-right: 8px;
padding-left: 8px
}
.btn_boot-group > .btn_boot-lg + .dropdown-toggle {
padding-right: 12px;
padding-left: 12px
}
.btn_boot-group.open .dropdown-toggle {
-webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125)
}
.btn_boot-group.open .dropdown-toggle.btn_boot-link {
-webkit-box-shadow: none;
box-shadow: none
}
.btn_boot .caret {
margin-left: 0
}
.btn_boot-lg .caret {
border-width: 5px 5px 0;
border-bottom-width: 0
}
.dropup .btn_boot-lg .caret {
border-width: 0 5px 5px
}
.btn_boot-group-vertical > .btn_boot, .btn_boot-group-vertical > .btn_boot-group, .btn_boot-group-vertical > .btn_boot-group > .btn_boot {
display: block;
float: none;
width: 100%;
max-width: 100%
}
.btn_boot-group-vertical > .btn_boot-group > .btn_boot {
float: none
}
.btn_boot-group-vertical > .btn_boot + .btn_boot, .btn_boot-group-vertical > .btn_boot + .btn_boot-group, .btn_boot-group-vertical > .btn_boot-group + .btn_boot, .btn_boot-group-vertical > .btn_boot-group + .btn_boot-group {
margin-top: -1px;
margin-left: 0
}
.btn_boot-group-vertical > .btn_boot:not(:first-child):not(:last-child) {
border-radius: 0
}
.btn_boot-group-vertical > .btn_boot:first-child:not(:last-child) {
border-top-left-radius: 4px;
border-top-right-radius: 4px;
border-bottom-right-radius: 0;
border-bottom-left-radius: 0
}
.btn_boot-group-vertical > .btn_boot:last-child:not(:first-child) {
border-top-left-radius: 0;
border-top-right-radius: 0;
border-bottom-right-radius: 4px;
border-bottom-left-radius: 4px
}
.btn_boot-group-vertical > .btn_boot-group:not(:first-child):not(:last-child) > .btn_boot {
border-radius: 0
}
.btn_boot-group-vertical > .btn_boot-group:first-child:not(:last-child) > .btn_boot:last-child, .btn_boot-group-vertical > .btn_boot-group:first-child:not(:last-child) > .dropdown-toggle {
border-bottom-right-radius: 0;
border-bottom-left-radius: 0
}
.btn_boot-group-vertical > .btn_boot-group:last-child:not(:first-child) > .btn_boot:first-child {
border-top-left-radius: 0;
border-top-right-radius: 0
}
.btn_boot-group-justified {
display: table;
width: 100%;
table-layout: fixed;
border-collapse: separate
}
.btn_boot-group-justified > .btn_boot, .btn_boot-group-justified > .btn_boot-group {
display: table-cell;
float: none;
width: 1%
}
.btn_boot-group-justified > .btn_boot-group .btn_boot {
width: 100%
}
.btn_boot-group-justified > .btn_boot-group .dropdown-menu {
left: auto
}
.btn_boot {
display: inline-block;
padding: 6px 12px;
margin-bottom: 0;
font-size: 14px;
font-weight: bolder;
line-height: 0.9;
text-align: center;
white-space: nowrap;
vertical-align: middle;
-ms-touch-action: manipulation;
touch-action: manipulation;
cursor: pointer;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
background-image: none;
border: 1px solid transparent;
border-radius: 4px;
}
.btn_boot.active.focus, .btn_boot.active:focus, .btn_boot.focus, .btn_boot:active.focus, .btn_boot:active:focus, .btn_boot:focus {
}
.btn_boot.focus, .btn_boot:focus, .btn_boot:hover {
color: #333;
text-decoration: none
}
.btn_boot.active, .btn_boot:active {
background-image: none;
outline: 0;
}
.btn_boot.disabled, .btn_boot[disabled], fieldset[disabled] .btn_boot {
cursor: not-allowed;
filter: alpha(opacity=65);
-webkit-box-shadow: none;
box-shadow: none;
opacity: .65
}
a.btn_boot.disabled, fieldset[disabled] a.btn_boot {
pointer-events: none
}
.btn_boot-default {
color: #333;
background-color: #eeeeee;
border-color: #D5D5D5
}
.btn_boot-default.focus, .btn_boot-default:focus {
color: #333;
background-color: #eeeeee;
border-color: #D5D5D5
}
.btn_boot-default:hover {
color: #333;
background-color: #eeeeee;
border-color: #D5D5D5
}
.btn_boot-default.active, .btn_boot-default:active, .open > .dropdown-toggle.btn_boot-default {
color: #333;
background-color: #DDDDDD;
border-color: #D5D5D5
}
.btn_boot-default.active.focus, .btn_boot-default.active:focus, .btn_boot-default.active:hover, .btn_boot-default:active.focus, .btn_boot-default:active:focus, .btn_boot-default:active:hover, .open > .dropdown-toggle.btn_boot-default.focus, .open > .dropdown-toggle.btn_boot-default:focus, .open > .dropdown-toggle.btn_boot-default:hover {
color: #333;
background-color: #DDDDDD;
border-color: #D5D5D5
}
.btn_boot-default.active, .btn_boot-default:active, .open > .dropdown-toggle.btn_boot-default {
background-image: none
}
.btn_boot-default.disabled.focus, .btn_boot-default.disabled:focus, .btn_boot-default.disabled:hover, .btn_boot-default[disabled].focus, .btn_boot-default[disabled]:focus, .btn_boot-default[disabled]:hover, fieldset[disabled] .btn_boot-default.focus, fieldset[disabled] .btn_boot-default:focus, fieldset[disabled] .btn_boot-default:hover {
background-color: #fff;
border-color: #D5D5D5
}
.btn_boot-default .badge {
color: #fff;
background-color: #8c8c8c
}
</style>
<div class="btn_boot-group" style="
width: 190px;
margin: 0 auto;
height: 26px;
align-self: center;
text-align: center;
" innerId="group">
<button type="button" class="btn_boot btn_boot-default" innerId="funnel">Воронка</button>
<button type="button" class="btn_boot btn_boot-default active" innerId="canban">Канбан</button>
</div>
```
JAVASCRIPT код:
``` xml
$(".btn_boot-group > .btn_boot").click(function(){
$(this).addClass("active").siblings().removeClass("active");
});
var funnel = jQuery(view.container[0]).children("[innerId='group']").children("[innerId='funnel']");
funnel.text(i18n.tr('Воронка'));
var canban = jQuery(view.container[0]).children("[innerId='group']").children("[innerId='canban']");
canban.text(i18n.tr('Канбан'));
var funnel_cmp = view.playerView.getViewWithId('crm_form_funnel_funnel');
var canban_cmp = view.playerView.getViewWithId('crm_form_funnel_canban');
var bottom_cmp = view.playerView.getViewWithId('crm_form_funnel_bottom_sum');
model.playerModel.funnelDrawn = false;
model.playerModel.canbanDrawn = false;
funnel.click(function(){
$('body').css('overflow', 'auto');
funnel_cmp.setVisible(true);
canban_cmp.setVisible(false);
bottom_cmp.setVisible(true);
model.playerModel.isFunnel = true;
if (!model.playerModel.funnelDrawn) {
model.playerModel.redraw();
}
});
canban.click(function(){
$('body').css('overflow', 'auto');
funnel_cmp.setVisible(false);
canban_cmp.setVisible(true);
bottom_cmp.setVisible(false);
model.playerModel.isFunnel = false;
if (!model.playerModel.canbanDrawn) {
model.playerModel.redraw();
}
});
```
#### crm_component_notifications {#crm2.uMNotifications}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Код | crm_component_notifications |
+--------------------------------------------------------+----------------------------------------------------------+
| Использовать в формах | выключен |
+--------------------------------------------------------+----------------------------------------------------------+
HTML код:
``` xml
<style>
.save_button_container {
text-align: center;
padding-top: 21px;
padding-bottom: 21px;
}
.notification-container {
width: 300px;
position: absolute;
bottom: 40px;
right: 15px;
}
.notification {
padding: 12px;
text-overflow: ellipsis;
white-space: nowrap;
width: 275px;
background-color: #ffffff;
border-radius: 5px;
box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
margin-top: 10px;
color: #606060;
font-size: 14px;
}
.info_block {
display: flex;
}
.link_block {
padding: 15px 0 15px 0;
width: 270px;
text-overflow: ellipsis;
white-space: nowrap;
overflow: hidden;
}
.button_success {
display: inline-block;
background-color: #49b785;
color: #ffffff;
height: 32px;
min-width: 32px;
padding-left: 30px;
padding-right: 30px;
-moz-padding-end: 25px;
-moz-padding-start: 25px;
border: none;
border-radius: 4px;
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
font-size: 14px;
font-weight: bold;
margin-left: 25px;
}
.button_remain {
display: inline-block;
background-color: #ffffff;
color: #606060;
height: 32px;
min-width: 32px;
padding-left: 30px;
padding-right: 30px;
-moz-padding-end: 25px;
-moz-padding-start: 25px;
border-radius: 4px;
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
font-size: 14px;
font-weight: bold;
border: 1px solid #e2e2e2;
}
.notification.more-notifications {
padding: 6px 9px 6px 15px;
text-overflow: ellipsis;
white-space: nowrap;
overflow: hidden;
}
.comment_block {
width: 250px;
text-overflow: ellipsis;
white-space: nowrap;
overflow: hidden;
opacity: 0.5;
}
.link_block a {
font-weight: bold;
color: #606060;
font-size: 14px;
}
.ring_block {
padding-right: 9px;
}
</style>
```
JAVASCRIPT код:
``` xml
var synergyURL = window.location.protocol + "//" + window.location.host + "/Synergy/";
AS.OPTIONS.coreUrl = synergyURL;
var putItem = setInterval(function () {
var element = jQuery('.popupMenuBlack.popupMenuItemLeftBlack.createButton table.popupMenuItemBlack > tbody > tr:last');
var elementLength = jQuery('.popupMenuBlack.popupMenuItemLeftBlack.createButton table.popupMenuItemBlack > tbody').length;
var el2 = jQuery('.popupMenuBlack.popupMenuItemLeftBlack.createButton table.popupMenuItemBlack > tbody > tr:last [title="Напоминание"]');
var menuHeight = jQuery('.popupMenuBlack.popupMenuItemLeftBlack.createButton table.popupMenuItemBlack').parent();
if (elementLength == 1 && el2.length == 0) {
element.after('<tr><td><table onmouseover="mouseOver(this)" onmouseout="mouseOut(this)" cellpadding="0" cellspacing="0" border="0" style="width: 100%; height: 24px;"><colgroup><col></colgroup><tbody><tr><td width="24px" class=""><img src="images/empty.gif" class="gwt-Image" style="width: 24px; height: 24px;"></td><td title="Напоминание" class="popup-menu-text" onclick="onItemClick()">Напоминание</td></tr></tbody></table></td></tr>')
menuHeight.height(menuHeight.height() + 30);
}
}, 100);
var onItemClick = function () {
var container = jQuery('<div></div>', {id: 'form_player_container'});
container.append(jQuery('<div></div>', {id: 'form_player_div'}));
var buttonContainer = jQuery('<div></div>', {class: 'save_button_container'});
var button = jQuery('<button id="save_button_task" class="button button-success" disabled>' + i18n.tr("Сохранить") + '</button>');
buttonContainer.append(button);
container.append(buttonContainer);
var dialog = container.dialog({
modal: true,
width: 600,
resizable: false,
close: function (event, ui) {
dialog.dialog('destroy').remove();
},
title: i18n.tr("Создание напоминания")
});
button.click(function () {
var data = getData();
saveTask(data, function (result) {
notShowed.push({
taskID: JSON.parse(result).taskID,
taskObject: getTaskObjectArray(data.task),
start: data.start,
finish: data.finish,
task: data.task
});
dialog.dialog('destroy').remove();
});
});
jQuery('.popupMenuItemLeftBlack').hide();
portal.createPlayer();
};
function getData() {
var dict = portal.player.model.getModelWithId('dict').getTextValue();
var task = portal.player.model.getModelWithId('comment').getValue();
if (!task || task == 'null') {
task = '';
}
var start = portal.player.model.getModelWithId('start').getValue();
var lead = portal.player.model.getModelWithId('lead');
var leadId = lead.getValue();
var leadName = lead.getTextValue();
var breakChar = String.fromCharCode(13);
var result = 'Напоминание!' + breakChar +
dict + breakChar +
leadName + breakChar +
'#submodule=common&action=open_document&document_identifier=' + leadId + breakChar +
breakChar +
task;
return {
task: result,
start: start,
finish: start.substr(0, start.indexOf(' ')) + " 23:59:00"
};
}
var mouseOver = function (element) {
element.style.backgroundColor = '#E4EEF5';
};
var mouseOut = function (element) {
element.style.backgroundColor = '';
};
var portal = {
player: null,
clearPlayer: function () {
if (portal.player) {
portal.player.destroy();
}
jQuery("#save_button_task").attr('disabled');
portal.player = null;
},
/**
* добавить новый проигрыватель форм
*/
createPlayer: function (dataId) {
portal.clearPlayer();
portal.player = AS.FORMS.createPlayer();
portal.player.model.on(AS.FORMS.EVENT_TYPE.valueChange, function (event, model, view) {
var task = portal.player.model.getModelWithId('comment');
var start = portal.player.model.getModelWithId('start');
var lead = portal.player.model.getModelWithId('lead');
if (!task || !start || !lead) {
return;
}
var startValue = start.getValue();
var leadValue = lead.getValue();
if (startValue && leadValue) {
jQuery("#save_button_task").removeAttr('disabled', 'disabled');
} else {
jQuery("#save_button_task").attr('disabled', 'disabled');
}
});
portal.player.view.setEditable(true);
AS.SERVICES.showWaitWindow();
var handler = function (definition, data) {
portal.player.model.buildModelsDefinition(definition, null);
AS.SERVICES.hideWaitWindow();
if (data) {
portal.player.model.setAsfData(data);
}
};
jQuery.when(loadDefaultAsfData("crm_form_task"))
.then(function (data) {
jQuery.when(loadFormDefinition("crm_form_task", 0), data).then(handler);
});
portal.player.view.appendTo($('#form_player_div'));
//jQuery('.asf-datePopup').datepicker("option", "minDate", new Date(2016, 12, 21));
}
};
function loadDefaultAsfData(formCode) {
return AS.FORMS.ApiUtils.simpleAsyncGet('rest/api/asforms/getDefaultContent?formCode=' + formCode);
}
function loadFormDefinition(code, version) {
if (version) {
return AS.FORMS.ApiUtils.simpleAsyncGet('rest/api/asforms/form_ext?formCode=' + code + "&version=" + version);
} else {
return AS.FORMS.ApiUtils.simpleAsyncGet('rest/api/asforms/form_ext?formCode=' + code);
}
}
function loadTasks(handler) {
var currentDate = $.datepicker.formatDate('yy-mm-dd', new Date());
var finish = new Date();
finish.setDate(finish.getDate() + 7);
var finishDate = $.datepicker.formatDate('yy-mm-dd', finish);
return AS.FORMS.ApiUtils.simpleAsyncGet('rest/api/diary/tasks/' + AS.OPTIONS.currentUser.userId + '/all?start=' + currentDate + '&finish=' + finishDate, handler);
}
function completeTask(taskID) {
return AS.FORMS.ApiUtils.simpleAsyncGet('rest/api/diary/tasks/complete?taskID=' + taskID);
}
function remainLater(data, handler) {
return saveTask(data);
}
function saveTask(data, handler) {
return AS.FORMS.ApiUtils.simpleAsyncPost('rest/api/diary/tasks/' + AS.OPTIONS.currentUser.userId + '/save',
AS.FORMS.ApiUtils.getHandler(handler, true), "text", data, undefined, function () {
});
}
function createNotification(taskObject, taskID) {
var remain = jQuery('<button class="button_remain" taskID="' + taskID + '">' + i18n.tr("Отложить") + '</button>');
var close = jQuery('<button class="button_success" taskID="' + taskID + '">' + i18n.tr("Закрыть") + '</button>');
close.click(function (event) {
var button = jQuery(event.target);
var taskID = button.attr('taskID');
completeTask(taskID);
for (var i = 0; i < showed.length; i++) {
if (showed[i].taskID === taskID) {
showed.splice(i, 1);
break;
}
}
showNotify();
});
remain.click(function (event) {
var button = jQuery(event.target);
var taskID = button.attr('taskID');
for (var i = 0; i < showed.length; i++) {
if (showed[i].taskID === taskID) {
var element = showed[i];
var now = new Date();
now.setMinutes(now.getMinutes() + 15);
element.start = AS.FORMS.DateUtils.formatDate(now, '${yyyy}-${mm}-${dd} ${HH}:${MM}:${SS}');
if (new Date(element.finish).getTime() < new Date(element.start).getTime()) {
now = new Date(element.finish);
now.setMinutes(now.getMinutes() + 15);
element.finish = AS.FORMS.DateUtils.formatDate(now, '${yyyy}-${mm}-${dd} ${HH}:${MM}:${SS}');
}
remainLater(element);
notShowed.push(element);
showed.splice(i, 1);
break;
}
}
showNotify();
});
var buttonBlock = jQuery('<div></div>', {class: 'button_block'});
buttonBlock.append(remain);
buttonBlock.append(close);
var infoBlock = jQuery('<div></div>', {class: 'info_block'});
var ring = jQuery('<div class="ring_block"><img src="data:image/jpeg;base64, ' + ringBase64 + '"/></div>');
infoBlock.append(ring);
var textInfo = jQuery('<div></div>', {class: 'text_info'});
var dictValue = jQuery('<div title="' + _.escape(taskObject[1]) + '" class="dict_block">' + taskObject[1] + '</div>');
textInfo.append(dictValue);
var comment = jQuery('<div title="' + _.escape(taskObject[5]) + '" class="comment_block">' + taskObject[5] + '</div>');
textInfo.append(comment);
infoBlock.append(textInfo);
var linkBlock = jQuery('<div class="link_block"><a title="' + _.escape(taskObject[2]) + '" href="' + taskObject[3] + '">' + taskObject[2] + '</a></div>');
var element = jQuery("<div class='notification'></div>");
element.append(infoBlock);
element.append(linkBlock);
element.append(buttonBlock);
return element;
}
/**
* Проверка не наступило ли время уведомления
*/
function checkTimeInArray() {
setInterval(function () {
var tmp = [];
var addedNotify = false;
notShowed.forEach(function (task) {
var object = {
taskID: task.taskID,
taskObject: task.taskObject,
start: task.start,
task: task.task,
finish: task.finish
};
if (isTimeToShow(task.start)) {
showed.push(object);
addedNotify = true;
} else {
tmp.push(object);
}
});
notShowed = tmp;
if (addedNotify) {
showNotify();
}
}, 1000);
}
/**
* Отображение уведомлений, берет массив уведомлений которые необходимо показать и отображает их
*/
function showNotify() {
clearAllNotifications();
var tmp = 0;
var more = 0;
for (var i = showed.length - 1; i >= 0; i--) {
var task = showed[i];
if (tmp < 3) {
notificationPanel.append(createNotification(task.taskObject, task.taskID));
} else {
more++;
}
tmp++;
}
if (more > 0) {
notificationPanel.append(jQuery('<div class="notification more-notifications">' + i18n.tr("Еще напоминаний:") + ' ' + more + '</div>'));
}
}
/**
* Наступило ли время для показа уведомления
*/
function isTimeToShow(start) {
return new Date().getTime() > new Date(start).getTime();
}
/**
* Отчистка всех уведомлений
*/
function clearAllNotifications() {
jQuery('.notification').remove();
}
/**
* Создана ли заметка через нужную форму
*/
function isValidTask(taskObject) {
return taskObject[0] == 'Напоминание!' && taskObject.length == 6;
}
/**
* Получение массива объектов (разделены переносами)
*/
function getTaskObjectArray(task) {
return task.split(String.fromCharCode(13));
}
/**
* Вставка панели уведомлений
*/
jQuery(document).ready(function () {
var checkExist = setInterval(function () {
if (AS.OPTIONS.login && AS.OPTIONS.login != '') {
addPanel();
clearInterval(checkExist);
}
}, 100);
});
var notificationPanel = jQuery("<div class='notification-container'></div>");
var showed = [];
var notShowed = [];
function addPanel() {
jQuery("body").append(notificationPanel)
notificationPanel.show(function () {
loadTasks(function (data) {
clearAllNotifications();
data.forEach(function (task) {
var taskObject = getTaskObjectArray(task.task);
if (isValidTask(taskObject)) {
var object = {
taskID: task.taskID,
taskObject: taskObject,
start: task.start,
task: task.task,
finish: task.finish
};
if (isTimeToShow(task.start)) {
showed.push(object);
} else {
notShowed.push(object);
}
}
});
checkTimeInArray();
showNotify();
});
});
}
//Иконка колокольчика
var ringBase64 = 'iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAQAAABKfvVzAAAACXBIWXMAAAsTAAALEwEAmpwYAAADGGlDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjaY2BgnuDo4uTKJMDAUFBUUuQe5BgZERmlwH6egY2BmYGBgYGBITG5uMAxIMCHgYGBIS8/L5UBFTAyMHy7xsDIwMDAcFnX0cXJlYE0wJpcUFTCwMBwgIGBwSgltTiZgYHhCwMDQ3p5SUEJAwNjDAMDg0hSdkEJAwNjAQMDg0h2SJAzAwNjCwMDE09JakUJAwMDg3N+QWVRZnpGiYKhpaWlgmNKflKqQnBlcUlqbrGCZ15yflFBflFiSWoKAwMD1A4GBgYGXpf8EgX3xMw8BSMDVQYqg4jIKAUICxE+CDEESC4tKoMHJQODAIMCgwGDA0MAQyJDPcMChqMMbxjFGV0YSxlXMN5jEmMKYprAdIFZmDmSeSHzGxZLlg6WW6x6rK2s99gs2aaxfWMPZ9/NocTRxfGFM5HzApcj1xZuTe4FPFI8U3mFeCfxCfNN45fhXyygI7BD0FXwilCq0A/hXhEVkb2i4aJfxCaJG4lfkaiQlJM8JpUvLS19QqZMVl32llyfvIv8H4WtioVKekpvldeqFKiaqP5UO6jepRGqqaT5QeuA9iSdVF0rPUG9V/pHDBYY1hrFGNuayJsym740u2C+02KJ5QSrOutcmzjbQDtXe2sHY0cdJzVnJRcFV3k3BXdlD3VPXS8Tbxsfd99gvwT//ID6wIlBS4N3hVwMfRnOFCEXaRUVEV0RMzN2T9yDBLZE3aSw5IaUNak30zkyLDIzs+ZmX8xlz7PPryjYVPiuWLskq3RV2ZsK/cqSql01jLVedVPrHzbqNdU0n22VaytsP9op3VXUfbpXta+x/+5Em0mzJ/+dGj/t8AyNmf2zvs9JmHt6vvmCpYtEFrcu+bYsc/m9lSGrTq9xWbtvveWGbZtMNm/ZarJt+w6rnft3u+45uy9s/4ODOYd+Hmk/Jn58xUnrU+fOJJ/9dX7SRe1LR68kXv13fc5Nm1t379TfU75/4mHeY7En+59lvhB5efB1/lv5dxc+NH0y/fzq64Lv4T8Ffp360/rP8f9/AA0ADzT6lvFdAAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAADBSURBVHjazJSxDoIwEIa/Etkc9AEclAchrizMbMaEnTegr2GcfQPiyovgZgLv4FAXlQo9hRATb2rv7rvr31yrDOPMG5nP7LnY2l5FBJyx2pcfO0QUFERDj+QRAxC7on1XQkUKQEpFImp4WMoB9dqtOTHn+CbP2KJXXPA7JW5suEqis146+GSyhtB5Z6EMBE4gkIGFE1hOGo0/B7SYpV2AJheBvEXa0fjy9ErVHT41RXSNwVAPB/Y0NOxcIfXzX+M+ACEjIJk9xFSpAAAAAElFTkSuQmCC';
```
#### crm_component_registry_chooser {#crm2.uMRegistryChooser}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Код | crm_component_registry_chooser |
+--------------------------------------------------------+----------------------------------------------------------+
| Использовать в формах | включен |
+--------------------------------------------------------+----------------------------------------------------------+
HTML код:
``` xml
<style>
.edit {
border: 1px solid black;
float: right;
background: url('light/images/buttons/dark.gray/edit.png') 50%;
width: 30px;
height: 22px;
background-repeat: no-repeat;
border-radius: 5px;
border-color: gray;
}
.edited{
background-color: #efefef;
}
</style>
<div innerId="textView" style="text-decoration:underline; cursor:pointer;width:calc(100% ); color:#06f; margin-bottom:2px"></div>
<input type="text" class="asf-textBox" innerId="name" style="width:calc(100% )"/>
<div style="color:#606060; text-decoration:underline" class="asf-InlineBlock asf-cursorPointer" innerId="add">+Создать</div>
<div style="color:#606060; margin-left:10px; text-decoration:underline" class="asf-InlineBlock asf-cursorPointer" innerId="browse">Выбрать из реестра</div>
<div style="color:#606060; margin-left:10px; text-decoration:underline" class="asf-InlineBlock asf-cursorPointer" innerId="delete">&#10005; Удалить</div>
```
JAVASCRIPT код:
``` xml
/**
* обновить текстовое представление записи реестра
*/
model.updateTextView = function () {
if (!model.getValue()) {
model.textValue = "";
model.asfDataId = null;
model.trigger(AS.FORMS.EVENT_TYPE.dataLoad, [model]);
return;
}
AS.FORMS.ApiUtils.getAsfDataUUID(model.getValue(), function (newAsfDataId) {
model.asfDataId = newAsfDataId;
AS.FORMS.ApiUtils.getDocMeaningContent(registry.registryID, newAsfDataId, function (text) {
if (text === null || text === '') {
model.textValue = i18n.tr('Документ');
} else {
model.textValue = text;
}
model.trigger(AS.FORMS.EVENT_TYPE.dataLoad, [model]);
});
});
};
/**
* получить тесктовое представление записи реестра
* @returns {string|string|*}
*/
model.getTextValue = function () {
return model.textValue;
};
// подписываемся на событие модели об изменении содержания, чтобы подгрузить дополнительные данные
model.on(AS.FORMS.EVENT_TYPE.valueChange, function () {
model.updateTextView();
});
/**
* метод реализовывает вставку asfData
* @param asfData
*/
model.setAsfData = function (asfData) {
model.setValue(asfData.key);
};
/**
* метод реализовывает получение данных компонента для сохранения
* @param blockNumber
* @returns {*}
*/
model.getAsfData = function (blockNumber) {
return AS.FORMS.ASFDataUtils.getBaseAsfData(model.asfProperty, blockNumber, model.textValue, model.value);
};
/* инициализация отображения */
/**
* реестр
* @type {object}
*/
var registry = null;
/**
* видимые колонки реестра
* @type {Array}
*/
var registryColumns = [];
/**
* поле ввода для поиска записей реестра
* @type {XMLList|*}
*/
var input = jQuery(view.container).children("[innerId='name']");
/**
* поле для отображения выбранной записи реестра
* @type {XMLList|*}
*/
var textView = jQuery(view.container).children("[innerId='textView']");
/**
* кнопка добавления записи
* @type {XMLList|*}
*/
var addIcon = jQuery(view.container).children("[innerId='add']");
/**
* кнопка выбора записи из реестра
* @type {XMLList|*}
*/
var browseIcon = jQuery(view.container).children("[innerId='browse']");
/**
* кнопка удаления текущей выбранной записи
* @type {XMLList|*}
*/
var deleteIcon = jQuery(view.container).children("[innerId='delete']");
// кнопку удаления текущей выбраннйо записи скрываем
deleteIcon.hide();
// по нажатию на кнопку "выбрать из реестра" открываем стандартный диалог выбра записи реестра
browseIcon.click(function () {
AS.SERVICES.showRegisterLinkDialog(registry, function (documentId) {
model.setValue(documentId);
});
});
// по нажатию на кнопку "создать" открываем форму создания записи реестра
addIcon.click(function () {
if (!registry.rr_create) {
alert("У вас нет прав на создание записей данного реестра");
return;
}
var createPlayerDiv = jQuery("<div>");
createPlayerDiv.css("width", "1000px");
createPlayerDiv.css("height", "700px");
createPlayerDiv.css("border", "1px solid #afafaf");
var saveButton = jQuery("<button>", {class: "ns-approveButton ns-basicChooserApplyButton"});
saveButton.button();
saveButton.html(i18n.tr("Создать"));
saveButton.css("margin", "auto");
saveButton.css("display", "block");
saveButton.css("margin-top", "10px");
saveButton.css("margin-bottom", "10px");
var player = AS.FORMS.createPlayer();
player.view.setEditable(true);
player.showFormData(registry.formId);
player.view.appendTo(createPlayerDiv);
player.model.on(AS.FORMS.EVENT_TYPE.dataLoad, function () {
console.log(player.model);
var registryModel = null;
if (player.model.formCode === 'crm_form_contact') {
registryModel = player.model.getModelWithId('crm_form_contact_lead_lead', 'crm_form_contact_lead');
}
if (player.model.formCode === 'crm_form_account') {
registryModel = player.model.getModelWithId('crm_form_account_lead_lead', 'crm_form_account_lead');
}
if (player.model.formCode === 'crm_form_dealActivity') {
registryModel = player.model.getModelWithId('crm_form_dealActivity_main_deal');
}
if (player.model.formCode === 'crm_form_leadActivity') {
registryModel = player.model.getModelWithId('crm_form_leadActivity_main_lead');
}
if (registryModel != null) {
registryModel.setValue(AS.SERVICES.getParameterByName("document_identifier", window.location.href));
}
});
createPlayerDiv.append(saveButton);
createPlayerDiv.dialog({
width: 1000,
height: 700,
modal: true
});
saveButton.click(function () {
var valid = player.model.isValid();
if (!valid) {
alert(i18n.tr("Введите все обязательные поля"));
return;
}
AS.SERVICES.showWaitWindow();
AS.FORMS.ApiUtils.simpleAsyncGet("rest/api/registry/create_doc?registryID=" + registry.registryID, function (result) {
if (result.errorCode != 0) {
AS.SERVICES.hideWaitWindow();
alert(i18n.tr("Во время сохранения данных по форме произошли ошибки. Обратитесь к администратору"));
return;
}
player.model.asfDataId = result.dataUUID;
player.saveFormData(function (result) {
AS.SERVICES.hideWaitWindow();
if (_.isUndefined(result)) {
alert(i18n.tr("Во время сохранения данных по форме произошли ошибки. Обратитесь к администратору"));
return;
};
createPlayerDiv.dialog("destroy");
AS.FORMS.ApiUtils.getDocumentIdentifier(result, function (documentID) {
model.setValue(documentID);
});
});
});
});
});
// по нажатию на кнопку удалить - удаляем выбранное значение
deleteIcon.click(function(){
model.setValue(null);
});
// по нажатию на текстовое отображение - открываем запись реестра на просмотр
textView.click(function () {
var createPlayerDiv = jQuery("<div>");
createPlayerDiv.css("width", "1000px");
createPlayerDiv.css("height", "700px");
var editButton = jQuery('<div class="edit"></div>');
var saveButton = jQuery("<button>", {class: "ns-approveButton ns-basicChooserApplyButton"});
saveButton.button();
saveButton.html(i18n.tr("Сохранить"));
saveButton.css("margin", "auto");
saveButton.css("display", "block");
saveButton.css("margin-top", "10px");
saveButton.css("margin-bottom", "10px");
if (registry.code == 'crm_registry_leadActivities' || registry.code == 'crm_registry_dealActivities') {
createPlayerDiv.append(editButton);
editButton.click(function () {
if (player.view.editable) {
player.view.setEditable(false);
editButton.removeClass('edited');
saveButton.hide();
} else {
player.view.setEditable(true);
editButton.addClass('edited');
saveButton.show();
}
});
}
createPlayerDiv.css("border", "1px solid #afafaf");
var player = AS.FORMS.createPlayer();
player.view.setEditable(false);
player.showFormData(null, null, model.asfDataId, 0);
player.view.appendTo(createPlayerDiv);
createPlayerDiv.append(saveButton);
saveButton.hide();
createPlayerDiv.dialog({
width: 1000,
height: 700,
modal: true
});
saveButton.click(function () {
var valid = player.model.isValid();
if (!valid) {
alert(i18n.tr("Введите все обязательные поля"));
return;
}
AS.SERVICES.showWaitWindow();
player.saveFormData(function (result) {
AS.SERVICES.hideWaitWindow();
if (_.isUndefined(result)) {
alert(i18n.tr("Во время сохранения данных по форме произошли ошибки. Обратитесь к администратору"));
return;
}
;
createPlayerDiv.dialog("destroy");
AS.FORMS.ApiUtils.getDocumentIdentifier(result, function (documentID) {
model.setValue(documentID);
});
});
});
});
// скрываем или отображаем поля ввода в зависимости от того режим чтения это или редактирования
if (editable) {
//textView.hide();
} else {
input.hide();
addIcon.hide();
browseIcon.hide();
deleteIcon.hide();
}
addIcon.text('+' + i18n.tr('Создать'));
browseIcon.text(i18n.tr('Выбрать из реестра'));
deleteIcon.html('<div style="color:#606060; margin-left:10px; text-decoration:underline" class="asf-InlineBlock asf-cursorPointer" innerId="delete">&#10005;' + i18n.tr('Удалить') + '</div>');
// реализовываем метод обновления отображения согласно изменившимся данным модели
view.updateValueFromModel = function () {
input.val("");
if (model.getValue()) {
textView.css("display", "");
input.hide();
textView.html(model.getTextValue());
input.hide();
if (editable) {
deleteIcon.css("display", "");
} else {
input.hide();
addIcon.hide();
browseIcon.hide();
deleteIcon.hide();
}
} else {
if (editable) {
input.css("display", "");
} else {
input.hide();
addIcon.hide();
browseIcon.hide();
deleteIcon.hide();
}
textView.html("");
input.text("");
deleteIcon.hide();
}
};
// подписываем на событие подгрузки дополнительных данных значения
model.on(AS.FORMS.EVENT_TYPE.dataLoad, function () {
view.updateValueFromModel();
});
/**
* если нет прав создания записи реестра, то кнопки создать не должно быть видно
*/
function validateIconsState() {
addIcon.hide();
if (registry.rr_create && editable) {
addIcon.css("display", "");
}
}
/**
* инициализируем компонент (получаем реестр, колонки)
*/
function initComponent() {
AS.FORMS.ApiUtils.simpleAsyncGet('rest/api/registry/info?code=' + model.code, function (reg) {
registry = reg;
registry.registryID = reg.registryID;
registryColumns = [];
registry.columns.forEach(function (col) {
if (col.visible != 1) {
return;
}
registryColumns.push(col);
});
registryColumns = registryColumns.sort(function (item1, item2) {
var number1 = item1.order;
var number2 = item2.order;
if (number1 === number2) {
if (item1.name < item2.name) {
return -1;
} else if (item1.name > item2.name) {
return 1;
}
} else {
if (number1 === 0) {
return 1;
} else if (number2 === 0) {
return -1;
} else if (number1 < number2) {
return -1;
} else {
return 1;
}
}
return 0;
});
model.updateTextView();
view.updateValueFromModel();
validateIconsState();
});
}
// при вводе пользователя отображаем первые 10 результатов поиска
input.on("input", function () {
var search = input.val();
if (search.length === 0 || !registry) {
AS.SERVICES.showDropDown([]);
return;
}
AS.FORMS.ApiUtils.getRegistryData(registry.registryID, 0, 10, search, null, null, function (foundData) {
var values = [];
foundData.result.forEach(function (record) {
var value = {value: record.documentID};
var label = "";
registryColumns.forEach(function (column) {
if (record.fieldValue[column.columnID] !== undefined) {
label += record.fieldValue[column.columnID] + " - ";
}
});
value.title = label;
values.push(value);
});
AS.SERVICES.showDropDown(values, input, null, function (selectedValue) {
model.setValue(selectedValue);
view.updateValueFromModel();
});
});
});
setTimeout(function () {
initComponent();
}, 0);
AS.SERVICES.getParameterByName = function(name, url) {
if (!url) {
url = window.location.href;
}
name = name.replace(/[\[\]]/g, "\\$&");
var regex = new RegExp("[?&]" + name + "(=([^&#]*)|&|#|$)"),
results = regex.exec(url);
if (!results) return null;
if (!results[2]) return '';
return decodeURIComponent(results[2].replace(/\+/g, " "));
};
```
#### crm_component_social_links_accounts {#crm2.uMSocialLinksAccounts}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Код | crm_component_social_links_accounts |
+--------------------------------------------------------+----------------------------------------------------------+
| Использовать в формах | включен |
+--------------------------------------------------------+----------------------------------------------------------+
HTML код:
``` xml
<div class='social_link_account'>
<div class='social_element'></div>
</div>
```
JAVASCRIPT код:
``` xml
var longIlond = model.playerModel.getModelWithId('crm_form_lead_main_account');
var checkExist = setInterval(function () {
if (longIlond.asfDataId) {
doAny(longIlond.asfDataId);
clearInterval(checkExist);
}
}, 100);
longIlond.on(AS.FORMS.EVENT_TYPE.valueChange, function (event, model) {
var currentDataId = model.asfDataId;
var checkExist = setInterval(function () {
if (longIlond.asfDataId != currentDataId) {
doAny(longIlond.asfDataId);
clearInterval(checkExist);
}
}, 100);
doAny(model.asfDataId);
});
function doAny(dataId) {
var parent = jQuery('.social_link_account');
jQuery.when(AS.FORMS.ApiUtils.loadAsfData(dataId, 0)).then(function (data) {
parent.empty();
var list = getSocial('crm_form_account_socialNetworks', 'crm_form_account_socialNetworks_socialNetworks-b', 'crm_form_account_socialNetworks_socialNetworksCombo-b', data);
list.forEach(function (item) {
if (item.key == 'Facebook Messenger') {
createFacebookLink(item.value, parent);
}
if (item.key == 'Skype') {
createSkypeLink(item.value, parent);
}
})
list = getSocial('crm_form_account_phone', 'crm_form_account_phone_phone-b', 'crm_form_account_phone_phoneCombo-b', data);
list.forEach(function (item) {
if (item.key == 'Viber') {
createViberLink(item.value, parent);
}else if (item.key == 'Telegram') {
createTelegramLink(item.value, parent);
}else {
createTelephoneLink(item.value, parent);
}
})
list = getSocial('crm_form_account_email', 'crm_form_account_email_email-b', 'crm_form_account_email_emailCombo-b', data);
list.forEach(function (item) {
createMailLink(item.value, parent);
});
});
}
function createMailLink(value, parent){
if(value){
parent.append(jQuery('<div class="social_element mail"><a target="_blank" href="mailto:'+value+'">' + value + '</a></div>'));
}
}
function createViberLink(value, parent){
if(value){
parent.append(jQuery('<div class="social_element viber"><a target="_blank" href="viber://add?number='+value+'">' + value + '</a></div>'));
}
}
function createTelegramLink(value, parent){
if(value){
parent.append(jQuery('<div class="social_element telegram"><a target="_blank" href="https://telegram.me/'+value+'">' + value + '</a></div>'));
}
}
function createTelephoneLink(value, parent){
if(value){
parent.append(jQuery('<div class="social_element tel"><a target="_blank" href="tel:'+value+'">' + value + '</a></div>'));
}
}
function getSocial(idTable, valId, keyId, data) {
var found = data.data.filter(function (item) {
return item.id === idTable;
});
var list = [];
found[0].data.forEach(function (item) {
var id = item.id;
if (id.indexOf(valId) !== -1) {
var i = id.substring(id.indexOf(valId) + valId.length);
if (!list[i]) {
list[i] = {'value': item.value}
} else {
list[i].value = item.value;
}
}
if (id.indexOf(keyId) !== -1) {
var i = id.substring(id.indexOf(keyId) + keyId.length);
if (!list[i]) {
list[i] = {'key': item.value}
} else {
list[i].key = item.value;
}
}
});
return list;
}
function createFacebookLink(value, parent) {
var id;
if (value.indexOf("profile.php?id=") !== -1) {
id = value.substring(value.indexOf('profile.php?id=') + 'profile.php?id='.length);
} else {
id = value.substring(value.indexOf('facebook.com/') + 'facebook.com/'.length);
}
if (id) {
parent.append(jQuery('<div class="social_element facebook"><a target="_blank" href="http://m.me/' + id + '">' + value + '</a></div>'))
}
}
function createSkypeLink(value, parent) {
if(value){
parent.append(jQuery('<div class="social_element skype"><a target="_blank" href="skype:' + value + '?call">' + i18n.tr("Позвонить") + ' ' + value + '</a></div>'))
parent.append(jQuery('<div class="social_element skype"><a target="_blank" href="skype:' + value + '?chat">' + i18n.tr("Написать") + ' ' + value + '</a></div>'))
}
}
```
#### crm_component_social_links_contacts {#crm2.uMSocialLinksContacts}
+--------------------------------------------------------+----------------------------------------------------------+
| Свойство | Значение |
+========================================================+==========================================================+
| Код | crm_component_social_links_contacts |
+--------------------------------------------------------+----------------------------------------------------------+
| Использовать в формах | включен |
+--------------------------------------------------------+----------------------------------------------------------+
HTML код:
``` xml
<style>
.social_element{
padding-left: 20px;
padding-bottom: 5px;
}
.skype{
background: url('');
background-repeat: no-repeat;
}
.viber{
background: url('');
background-repeat: no-repeat;
}
.facebook{
background: url('');
background-repeat: no-repeat;
}
.telegram{
background: url('');
background-repeat: no-repeat;
}
.tel{
background: url('');
background-repeat: no-repeat;
}
.mail{
background: url('');
background-repeat: no-repeat;
}
</style>
<div class='social_link_contact'>
<div class='social_element'></div>
</div>
```
JAVASCRIPT код:
``` xml
var longIlond = model.playerModel.getModelWithId('crm_form_lead_main_contact');
var checkExist = setInterval(function () {
if (longIlond.asfDataId) {
doAny(longIlond.asfDataId);
clearInterval(checkExist);
}
}, 100);
longIlond.on(AS.FORMS.EVENT_TYPE.valueChange, function (event, model) {
var currentDataId = model.asfDataId;
var checkExist = setInterval(function () {
if (longIlond.asfDataId != currentDataId) {
doAny(longIlond.asfDataId);
clearInterval(checkExist);
}
}, 100);
doAny(model.asfDataId);
});
function doAny(dataId) {
var parent = jQuery('.social_link_contact');
jQuery.when(AS.FORMS.ApiUtils.loadAsfData(dataId, 0)).then(function (data) {
parent.empty();
var list = getSocial('crm_form_contact_socialNetworks', 'crm_form_contact_socialNetworks_socialNetworks-b', 'crm_form_contact_socialNetworks_socialNetworksCombo-b', data);
list.forEach(function (item) {
if (item.key == 'Facebook Messenger') {
createFacebookLink(item.value, parent);
}
if (item.key == 'Skype') {
createSkypeLink(item.value, parent);
}
})
list = getSocial('crm_form_contact_phone', 'crm_form_contact_phone_phone-b', 'crm_form_contact_phone_phoneCombo-b', data);
list.forEach(function (item) {
if (item.key == 'Viber') {
createViberLink(item.value, parent);
}else if (item.key == 'Telegram') {
createTelegramLink(item.value, parent);
}else {
createTelephoneLink(item.value, parent);
}
})
list = getSocial('crm_form_contact_email', 'crm_form_contact_email_email-b', 'crm_form_contact_email_emailCombo-b', data);
list.forEach(function (item) {
createMailLink(item.value, parent);
});
});
}
function createMailLink(value, parent){
if(value){
parent.append(jQuery('<div class="social_element mail"><a target="_blank" href="mailto:'+value+'">' + value + '</a></div>'));
}
}
function createViberLink(value, parent){
if(value){
parent.append(jQuery('<div class="social_element viber"><a target="_blank" href="viber://add?number='+value+'">' + value + '</a></div>'));
}
}
function createTelegramLink(value, parent){
if(value){
parent.append(jQuery('<div class="social_element telegram"><a target="_blank" href="https://telegram.me/'+value+'">' + value + '</a></div>'));
}
}
function createTelephoneLink(value, parent){
if(value){
parent.append(jQuery('<div class="social_element tel"><a target="_blank" href="tel:'+value+'">' + value + '</a></div>'));
}
}
function getSocial(idTable, valId, keyId, data) {
var found = data.data.filter(function (item) {
return item.id === idTable;
});
var list = [];
found[0].data.forEach(function (item) {
var id = item.id;
if (id.indexOf(valId) !== -1) {
var i = id.substring(id.indexOf(valId) + valId.length);
if (!list[i]) {
list[i] = {'value': item.value}
} else {
list[i].value = item.value;
}
}
if (id.indexOf(keyId) !== -1) {
var i = id.substring(id.indexOf(keyId) + keyId.length);
if (!list[i]) {
list[i] = {'key': item.value}
} else {
list[i].key = item.value;
}
}
});
return list;
}
function createFacebookLink(value, parent) {
var id;
if (value.indexOf("profile.php?id=") !== -1) {
id = value.substring(value.indexOf('profile.php?id=') + 'profile.php?id='.length);
} else {
id = value.substring(value.indexOf('facebook.com/') + 'facebook.com/'.length);
}
if (id) {
parent.append(jQuery('<div class="social_element facebook"><a target="_blank" href="http://m.me/' + id + '">' + value + '</a></div>'))
}
}
function createSkypeLink(value, parent) {
if(value){
parent.append(jQuery('<div class="social_element skype"><a target="_blank" href="skype:' + value + '?call">' + i18n.tr("Позвонить") + ' ' + value + '</a></div>'))
parent.append(jQuery('<div class="social_element skype"><a target="_blank" href="skype:' + value + '?chat">' + i18n.tr("Написать") + ' ' + value + '</a></div>'))
}
}
```
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment