1
0
mirror of https://github.com/Bayselonarrend/OpenIntegrations.git synced 2025-08-13 20:05:19 +02:00

Деффекты SC

This commit is contained in:
Anton
2024-01-26 22:01:11 +03:00
parent 706d9ca2b9
commit b582d4ae01
2 changed files with 443 additions and 251 deletions

View File

@@ -109,6 +109,7 @@
// Возвращаемое значение: // Возвращаемое значение:
// Строка, Произвольный, Неопределено, HTTPОтвет, ДвоичныеДанные - Изменить свойства страницы // Строка, Произвольный, Неопределено, HTTPОтвет, ДвоичныеДанные - Изменить свойства страницы
// @skip-check method-too-many-params // @skip-check method-too-many-params
// BSLLS:NumberOfOptionalParams-off
Функция ИзменитьСвойстваСтраницы(Знач Токен Функция ИзменитьСвойстваСтраницы(Знач Токен
, Знач Страница , Знач Страница
, Знач Данные = "" , Знач Данные = ""
@@ -118,6 +119,7 @@
Заголовки = СоздатьЗаголовкиЗапроса(Токен); Заголовки = СоздатьЗаголовкиЗапроса(Токен);
Параметры = Новый Структура; Параметры = Новый Структура;
Files = "files";
Если ЗначениеЗаполнено(Данные) И ТипЗнч(Данные) = Тип("Соответствие") Тогда Если ЗначениеЗаполнено(Данные) И ТипЗнч(Данные) = Тип("Соответствие") Тогда
Свойства = ЗаполнитьДанныеПоСхеме(Страница, Данные, Токен, Ложь); Свойства = ЗаполнитьДанныеПоСхеме(Страница, Данные, Токен, Ложь);
@@ -129,8 +131,8 @@
СоответствиеИконки = Новый Соответствие; СоответствиеИконки = Новый Соответствие;
СоответствиеИконки.Вставить("Icon", Иконка); СоответствиеИконки.Вставить("Icon", Иконка);
ОбъектИконка = ПреобразоватьЗначениеПоТипу("files", СоответствиеИконки); ОбъектИконка = ПреобразоватьЗначениеПоТипу(Files, СоответствиеИконки);
ОбъектИконка = ОбъектИконка["files"][0]; ОбъектИконка = ОбъектИконка[Files][0];
ОбъектИконка.Удалить("name"); ОбъектИконка.Удалить("name");
Параметры.Вставить("icon", ОбъектИконка); Параметры.Вставить("icon", ОбъектИконка);
@@ -140,8 +142,8 @@
СоответствиеОбложки = Новый Соответствие; СоответствиеОбложки = Новый Соответствие;
СоответствиеОбложки.Вставить("Cover", Обложка); СоответствиеОбложки.Вставить("Cover", Обложка);
ОбъектОбложка = ПреобразоватьЗначениеПоТипу("files", СоответствиеОбложки); ОбъектОбложка = ПреобразоватьЗначениеПоТипу(Files, СоответствиеОбложки);
ОбъектОбложка = ОбъектОбложка["files"][0]; ОбъектОбложка = ОбъектОбложка[Files][0];
ОбъектОбложка.Удалить("name"); ОбъектОбложка.Удалить("name");
Параметры.Вставить("cover", ОбъектОбложка); Параметры.Вставить("cover", ОбъектОбложка);
@@ -157,6 +159,7 @@
Возврат Ответ; Возврат Ответ;
КонецФункции КонецФункции
// BSLLS:NumberOfOptionalParams-on
#КонецОбласти #КонецОбласти
@@ -449,6 +452,7 @@
СтруктураДанных = Новый Структура; СтруктураДанных = Новый Структура;
СтруктураТекста = Новый Структура; СтруктураТекста = Новый Структура;
МассивДанных = Новый Массив; МассивДанных = Новый Массив;
Title = "title";
СтруктураТекста.Вставить("content", Заголовок); СтруктураТекста.Вставить("content", Заголовок);
СтруктураТекста.Вставить("link" , Неопределено); СтруктураТекста.Вставить("link" , Неопределено);
@@ -458,11 +462,11 @@
МассивДанных.Добавить(СтруктураДанных); МассивДанных.Добавить(СтруктураДанных);
ПодчиненнаяСтруктура.Вставить("id" , "title"); ПодчиненнаяСтруктура.Вставить("id" , Title);
ПодчиненнаяСтруктура.Вставить("type" , "title"); ПодчиненнаяСтруктура.Вставить("type" , Title);
ПодчиненнаяСтруктура.Вставить("title", МассивДанных); ПодчиненнаяСтруктура.Вставить(Title , МассивДанных);
ОсновнаяСтруктура.Вставить("title", ПодчиненнаяСтруктура); ОсновнаяСтруктура.Вставить(Title, ПодчиненнаяСтруктура);
КонецПроцедуры КонецПроцедуры
@@ -499,7 +503,7 @@
Или ТипЗнч(Свойство.Значение) = Тип("Соответствие") Тогда Или ТипЗнч(Свойство.Значение) = Тип("Соответствие") Тогда
ВыборЗначения = СформироватьЗначенияВыбора(Свойство.Значение); ВыборЗначения = СформироватьЗначенияВыбора(Свойство.Значение);
СоответствиеПараметров.Вставить(Свойство.Ключ, Новый Структура("select", ВыборЗначения)) СоответствиеПараметров.Вставить(Свойство.Ключ, Новый Структура("select", ВыборЗначения));
Иначе Иначе
@@ -589,7 +593,7 @@
Если Не Блок.Получить(Поле) = Неопределено Тогда Если Не Блок.Получить(Поле) = Неопределено Тогда
Блок.Удалить(Поле); Блок.Удалить(Поле);
КонецЕсли; КонецЕсли;
КонецЦикла КонецЦикла;
КонецПроцедуры КонецПроцедуры
@@ -610,7 +614,7 @@
ИначеЕсли Тип = "status" Тогда ИначеЕсли Тип = "status" Тогда
Возврат ПреобразоватьСтатус(Значение); Возврат ПреобразоватьСтатус(Значение);
ИначеЕсли Тип = "date" Тогда ИначеЕсли Тип = "date" Тогда
Возврат ПреобразоватьеДату(Значение); Возврат ПреобразоватьДату(Значение);
ИначеЕсли Тип = "relation" Тогда ИначеЕсли Тип = "relation" Тогда
Возврат ПреобразоватьСвязь(Значение); Возврат ПреобразоватьСвязь(Значение);
ИначеЕсли Тип = "people" Тогда ИначеЕсли Тип = "people" Тогда
@@ -697,7 +701,7 @@
КонецФункции КонецФункции
Функция ПреобразоватьеДату(Знач Дата) Функция ПреобразоватьДату(Знач Дата)
СтруктураДаты = Новый Структура; СтруктураДаты = Новый Структура;

View File

@@ -0,0 +1,188 @@
---
sidebar_position: 2
---
# Изменить свойства базы
Изменяет свойства созданной ранее базы
*Функция ИзменитьСвойстваБазы(Знач Токен, Знач База, Знач Свойства = "", Знач Заголовок = "", Знач Описание = "") Экспорт*
| Параметр | Тип | Назначение |
|-|-|-|
| Токен | Строка | Токен интеграции |
| База | Строка | ID базы |
| Свойства | Соответствие | Ключ - Имя изменяемого свойства, Значение - Тип или неопределено. Если неопределено - свойство удаляется |
Вовзращаемое значение: Соответствие - сериализованный JSON ответа от Notion
```bsl title="Пример кода"
Токен = "secret_9RsfMrRMqZwqp0Zl0B...";
База = "5dd94c34fab04bff9...";
ЗаголовокБазы = "Обновленный заголовок";
ОписаниеБазы = "Обновленное описание базы";
Свойства = Новый Соответствие;
Свойства.Вставить("Почта", "rich_text"); //Тип поля "Почта" будет изменен с email на текст
Свойства.Вставить("Сайт"); //Поле "Сайт" будет удалено
Ответ = OPI_Notion.ИзменитьСвойстваБазы(Токен, База, Свойства, ЗаголовокБазы, ОписаниеБазы);
Ответ = OPI_Инструменты.JSONСтрокой(Ответ);
```
![Результат](img/2.png)
```json title="Результат"
{
"request_id": "d42b5700-9325-439e-98ce-252a007f5ed7",
"public_url": null,
"url": "https://www.notion.so/048ba0ce4f474e33900540d249b01949",
"parent": {
"page_id": "5dd94c34-fab0-4bff-986b-7511c0779f77",
"type": "page_id"
},
"properties": {
"Картинка": {
"files": {},
"type": "files",
"name": "Картинка",
"id": "r%3Dfa"
},
"Активен": {
"checkbox": {},
"type": "checkbox",
"name": "Активен",
"id": "q%3FQF"
},
"Телефон": {
"phone_number": {},
"type": "phone_number",
"name": "Телефон",
"id": "hDII"
},
"Пользователь": {
"people": {},
"type": "people",
"name": "Пользователь",
"id": "%5D%40Md"
},
"Описание": {
"rich_text": {},
"type": "rich_text",
"name": "Описание",
"id": "KnG%3F"
},
"Статус": {
"select": {
"options": [
{
"description": null,
"color": "red",
"name": "Удаленный",
"id": "a71d6e8a-4f3e-4dfd-9f0e-4d90e400fde7"
},
{
"description": null,
"color": "yellow",
"name": "В работе",
"id": "aa6300b4-c635-4ab4-b5cd-87d14e45dd11"
},
{
"description": null,
"color": "green",
"name": "Новый",
"id": "202b1d30-2095-40f1-8b91-f627d475d560"
}
]
},
"type": "select",
"name": "Статус",
"id": "IDW%3C"
},
"Номер": {
"type": "number",
"name": "Номер",
"number": {
"format": "number"
},
"id": "CH__"
},
"Дата создания": {
"date": {},
"type": "date",
"name": "Дата создания",
"id": "BQN%5B"
},
"Имя": {
"title": {},
"type": "title",
"name": "Имя",
"id": "title"
},
"Почта": {
"rich_text": {},
"type": "rich_text",
"name": "Почта",
"id": "%3CO%3AD"
}
},
"last_edited_time": "2024-01-26T18:26:00.000Z",
"description": [
{
"plain_text": "Обновленное описание базы",
"annotations": {
"color": "default",
"code": false,
"underline": false,
"strikethrough": false,
"italic": false,
"bold": false
},
"text": {
"link": null,
"content": "Обновленное описание базы"
},
"href": null,
"type": "text"
}
],
"created_by": {
"id": "8b07422e-eeea-40d1-8d5e-c784211825b0",
"object": "user"
},
"archived": false,
"icon": null,
"created_time": "2024-01-26T16:49:00.000Z",
"title": [
{
"plain_text": "Обновленный заголовок",
"annotations": {
"color": "default",
"code": false,
"underline": false,
"strikethrough": false,
"italic": false,
"bold": false
},
"text": {
"link": null,
"content": "Обновленный заголовок"
},
"href": null,
"type": "text"
}
],
"cover": null,
"is_inline": false,
"id": "048ba0ce-4f47-4e33-9005-40d249b01949",
"last_edited_by": {
"id": "8b07422e-eeea-40d1-8d5e-c784211825b0",
"object": "user"
},
"object": "database"
}
```