Прикрепление внешних файлов к документам и справочникам 1С 8.3

06.04.23

Разработка - Инструментарий разработчика

В данной статье мы рассмотрим, как просто и быстро в любую конфигурацию добавить функционал прикрепления внешних файлов к документам и справочникам. Я начну описание с нуля, т.е. с создания пустой конфигурации. Так что даже любой малоопытный разработчик (вроде меня =) ) сможет реализовать данный функционал в своей или уже написанной конфигурации.

1. В табличную часть документация добавить реквизиты

  • Файл (ХранилищеЗначения)
  • ИмяФайла (неограничен)
  • РасширениеФайла

2. На форму добавить команды

  • ОткрытьФайл
  • ПосмотретьФайл

3. На форму добавить реквизиты

  • ИмяФайлаДиалог
  • ПутьКФайлу
  • РасширениеИзДиалога

4. В модуль формы написать код

//документация: схемы, чертежи заказа, примеры готовых изделий от клиента (имеется возможность их сохранения в базе данных)
//Документация может быть любого типа, включая различные документы.
//Пользователь может открыть загруженную документацию и посмотреть содержание документа.
//Если для просмотра документа на компьютере пользователя нет необходимого программного обеспечения, тогда должно отобразиться сообщение об этом. 
&НаКлиенте
Процедура ОткрытьФайл(Команда)
    
    Диалог = Новый ДиалогВыбораФайла(РежимДиалогаВыбораФайла.Открытие);
    Диалог.МножественныйВыбор = Ложь;
    Если Диалог.Выбрать() Тогда
        ПутьКФайлу = Диалог.ПолноеИмяФайла;
        ПозицияПоследнейТочкиВПолномИмениФайла = СтрНайти(ПутьКФайлу, ".", НаправлениеПоиска.СКонца,,1);
        ПозицияПоследнегоСловаСлева = СтрНайти(ПутьКФайлу,"\", НаправлениеПоиска.СКонца,,1);
        РасширениеИзДиалога = Прав(ПутьКФайлу,СтрДлина(ПутьКФайлу) - ПозицияПоследнейТочкиВПолномИмениФайла);
        ИмяФайлаДиалог = Сред(ПутьКФайлу, ПозицияПоследнегоСловаСлева + 1, ПозицияПоследнейТочкиВПолномИмениФайла - ПозицияПоследнегоСловаСлева - 1);    
    КонецЕсли; 
    
    Если Не ПутьКФайлу = "" Тогда
        ОткрытьФайлНаСервере();
        Элементы.ПосмотретьФайл.Доступность = Истина;
    Иначе
        Сообщить("Файл не выбран");
    КонецЕсли;

КонецПроцедуры

&НаСервере
Процедура ОткрытьФайлНаСервере()   
    
 ДокументОбъект = РеквизитФормыВЗначение("Объект"); //заись всего объекта конфигурации в переменную, чтобы обратиться потом к реквизиту с типом ХранилищеЗначения
  ДанныеФайла = Новый ДвоичныеДанные(ПутьКФайлу); //запись в переменную данных из реквизита ПутьКФайлу прибразованные в двоичные 
  КоличествоСтрок = ДокументОбъект.Документация.Количество();      // колво строк в табличной части, чтобы понимать к какой обращаться в те кущий момент
  ДокументОбъект.Документация.Добавить();
  ДокументОбъект.Документация[КоличествоСтрок].Файл = Новый ХранилищеЗначения(ДанныеФайла, Новый СжатиеДанных(9));
  ДокументОбъект.Документация[КоличествоСтрок].ИмяФайла = ИмяФайлаДиалог;
  ДокументОбъект.Документация[КоличествоСтрок].РасширениеФайла = РасширениеИзДиалога;
  ДокументОбъект.Записать();
  ЗначениеВРеквизитФормы(ДокументОбъект,"Объект");
    
    
КонецПроцедуры


&НаКлиенте
Процедура ПосмотретьФайл(Команда) 
    
     НомерТекущейСтроки = Элементы.Документация.ТекущиеДанные.НомерСтроки;
  ПросмотретьФайлНаСервере(НомерТекущейСтроки);
    
КонецПроцедуры


&НаСервере
Процедура ПросмотретьФайлНаСервере(НомерСтроки)
    
   ДокументОбъект = РеквизитФормыВЗначение("Объект");   
   Путь = ПолучитьИмяВременногоФайла(ДокументОбъект.Документация[НомерСтроки-1].РасширениеФайла);
   Данные = ДокументОбъект.Документация[НомерСтроки-1].Файл.Получить();
   Данные.Записать(Путь);
   ЗапуститьПриложение(Путь);
   ЗначениеВРеквизитФормы(ДокументОбъект,"Объект"); 
    
    
КонецПроцедуры 
  
                
&НаКлиенте
Процедура ПриОткрытии(Отказ) 
    
  ПриОткрытииНаСервере();    
  Если Объект.Документация.Количество() > 0 Тогда
    Элементы.ПосмотретьФайл.Доступность = Истина;
  Иначе
    Элементы.ПосмотретьФайл.Доступность = Ложь;
КонецЕсли;   

КонецПроцедуры  


&НаСервере
Процедура ПриОткрытииНаСервере() 
    
КонецПроцедуры  

5. Подключить процедуры к коду

6. Готово.

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

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

12000 руб.

02.09.2020    171823    962    403    

924

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    14333    109    46    

108

Пакетная печать Печатные формы Инструментарий разработчика Программист Платформа 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Инструмент, позволяющий абсолютно по-новому взглянуть на процесс разработки печатных форм. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и "прозрачность" разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    17292    43    15    

75

Инструментарий разработчика Программист Платформа 1С v8.3 1C:Бухгалтерия Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9360 руб.

17.05.2024    27288    96    48    

138

Инструменты администратора БД Инструментарий разработчика Роли и права Программист Платформа 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

15000 руб.

10.11.2023    11907    45    27    

67

SALE! %

Инструментарий разработчика Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия Россия Платные (руб)

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

4800 3840 руб.

14.01.2013    191251    1152    0    

920

Инструментарий разработчика Программист 8.3.14 Россия Платные (руб)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

20000 руб.

07.10.2021    18092    7    32    

42

Инструментарий разработчика Платформа 1С v8.3 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    1118    2    0    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. laperuz 47 06.04.23 09:08 Сейчас в теме
Почитайте про клиент-серверную архитектуру побольше.

1. В клиентском обработчике ПриОткрытии() делать серверный вызов - не айс, на сервере есть ПриСозданииНаСервере()
2. ЗапуститьПриложение() в серверном контексте сработает не так, как вы ожидаете, в случае, когда база не файловая и сервер 1С расположен физически на другой машине.
IgorS; DrAku1a; ixijixi; +3 Ответить
2. DrAku1a 1749 07.04.23 15:09 Сейчас в теме
1.) Кнопки называются "Добавить файл", "Удалить файл", "Открыть файл"
2.) Основной принцип - добавленные файлы помещаем на сервере во временное хранилище до момента записи объекта, на клиенте храним токены хранилища (и устанавливаем в Истина - модифицированность
3.) В "ПередЗаписьюНаСервере" - помещаем файлы из хранилища в ТекущийОбъект.Документация[...].Файл
4.) В "ПриЧтенииНаСервере" - помещаем все файлы из ТекущийОбъект.Документация[...].Файл во ВременноеХранилище, а в строке - заполняем токены.
Можно подумать как это оптимизировать.
И всё-же лучше файлы хранить не в ТЧ, а в отдельном справочнике или регистре сведений.
Так - при каждом чтении объекта на сервере не будут подгружаться все его файлы, и не будут перезаписываться все файлы при записи объекта.
3. ovasiliev 6 09.04.23 10:33 Сейчас в теме
Хранить файлы в элементах документов и справочников - моветон, от этого давно отказались.
Как написали выше - в регистр сведений их.
4. SUSI 18.12.23 09:10 Сейчас в теме
Добрый день!
Можно ли добавить еще и команду (и как это сделать) для сохранения прикрепленного в ТЧ файла на диск ?
Файлы, например, типа обработки или печатные формы 1С.
Оставьте свое сообщение