Новая версия VOGBIT 20.5 - Новая платформа: быстрее, надёжнее, удобнее. Новая подсистема управления приоритетами в производстве. Новые возможности для участков ЧПУ. Улучшенные «цеховые терминалы». Новые возможности для совместной работы менеджеров, инженеров и производства при изготовлении уникальной продукции под заказ. И многое другое…

Последние темы на форумах VOGBIT

Просьба объяснить нюансы в учете - Общие вопросы
Елена Ковалева: Еще вариант, если меню не настроено как у меня: во вложенном файле. Подробное описание в документации: https://vogbit.ru/support/622/#_v7660 https://vogbit.ru/support/622/#_v7660 рисунки 8-9.
Показ экскизов при выдаче со склада - Интерфейс программы
Alex-220781: Добрый день! Было бы неплохо сделать показ эскизов (как при просмотре справочника) при выдаче со склада.
Обновление 20.5. Произвольное выделение ячеек и строчек цветами. - Обновление
Сергей: Сейчас в этом месте можно использовать цифры 0 - минимальный, 1 - средний и т.д. (аналогично с фильтром) В некоторых колонках некоторых форм есть такая недоработка. Заметите - пишите. Будем исправлять.
Состав ЛЗК - Состав и технология
Наталья Захарова: Здравствуйте. Нашла на вашем канале Youtube видео "Предварительные заявки и ЛЗК в VOGBIT 20.5". Сделала все в точности, как показано, и стало все правильно получаться.
Документы - Прочее
Intelmine-tmc: Хорошо, спасибо большое
Автоматическая установка единиц измерения - Интерфейс программы
Константин Чилингаров: Значит сделали, но забыли отметить  :)  Бывает. Очень много разных доделок было в этот момент, что-то могли мелкое забыть "закрыть", как сделанное.
Задвоение рабочих заданий. - Производство
Константин Чилингаров: Здравствуйте, Судя по картинкам, если какое-то "задвоение" и имело место быть, то при "включении в план" из окна "новые задания". В 07:30 было создано 2 задания для поста. Должно было из быть 2 или нет - это из этих ...
Как привязать поставщика к поставщику - Общие вопросы
Serge.v.astapov: СПАСИБО!
Выбор технологии при создании производственного заказа - Состав и технология
Константин Чилингаров: Сделал ролик. Конкретно про выбор, какую версию использовать - начиная с 03:33 примерно. И дальше ещё есть, как назначить какой-то из вариантов "по умолчанию". [VIDEO TYPE=YOUTUBE WIDTH=1280 HEIGHT=720 //www.youtube.com/embed/7gywY9uRGeM ...
При изменении состава производственного заказа, необходимо удалить деталь - Прочее
Константин Чилингаров: Сегодня в течение дня отправим. На почту.
Производственные заказы - Общие вопросы
Константин Чилингаров: По поводу именно "высокого" уровня есть, кстати,  ещё разные "приёмы", сокращающие объём рутинных действий. Но они все специфичные, под конкретные случаи. Примеры: 1.  Для лазерной резки при больших объёмах есть технология инт ...
Неснижаемый остаток - Материалы, Комплектующие, Складской учёт
Константин Чилингаров: Вроде, починили ошибку. Хорошо бы ещё потестировать, конечно, какое-то время. Если сильно мешает работать, и нужно как можно скорее исправить в вашей версии программы, то пишите на почту, решим.
Как удалить сотрудников - Демо версия
Serge.v.astapov: Контантин, спасибо, не будем. Мы сегодня оплатим счет от ООО Светосистемы на лицензию. И начнем с чистого листа
Дополнительные колонки в составе изделия - Состав и технология
Михаил: Спасибо за оперативный ответ, помогло действительно простое обновление в окне "Состав"
Не получается отредактировать деталь - Демо версия
Serge.v.astapov: Константин, спасибо! Ключевым моментом было удаление заказов. Пошел дальше разбираться
Обновление 20.5. Система работы с «Предварительными заявками» и «Лимитно-заборными картами» - Обновление
Константин Чилингаров: 3520 Alex-220781 написал: В справочнике Ну... Может быть. Я просто в справочник особо не хожу на них смотреть (из серии, а чего на них там смотреть?  :) ). Сам обычно смотрю или из "Производственных заказов", или из "Обеспеченност ...
Удаление позиции в приходной накладной - Материалы, Комплектующие, Складской учёт
Константин Чилингаров: Ошибку нашли и починили. Штатно исправление войдёт в следующее обновление. Если сейчас мешает, то можем Вам и сейчас прямо починить. Для этого, пожалуйста, напишите на почту, я напишу в ответ, как сейчас починить можно.
Обновление 20.5. Строка поиска. - Обновление
Константин Чилингаров: Здравствуйте, По умолчанию, строка поиска открывается слева вверху (рис.1). Если уже включена панель группировки, то место слева вверху получается под группировку. В этом случае строка поиска открывается справа в этой же строчке (рис.2).
Обновление 20.5. Задачи и файлы - Обновление
Константин Чилингаров: Сделаем что-нибудь. Но время понадобится. Пример сделать нужно какой-нибудь, на котором объяснять и показывать. Займёмся...
удаленная работа - Общие вопросы
Константин Чилингаров: Текущая версия VOGBIT (20.5) работает под RDP (удалённый рабочий стол).

Пример создания плагина

Разработка приложений и функций - Плагины - Технические вопросы
Страницы: Пред. 1 2
Пример создания плагина
 
вопрос исчерпан! все по цепочке коллекция компонентов-компоненты-параметры и quontity найден
 
да, правильно
 
оказалось в sql просто :D, а в c# как половчее сделать?
 
Непонятен вопрос.

Есть объект "деталь" (номенклатура).
У него есть объекты - коллекции компонентов. В общем случае их много. Кто из них "техпроцесс", определяется по типу связи коллекции.

В коллекции есть компоненты (операции, материалы и др.). Кто из компонентов есть кто, определяется по типу связи компонента.

Норма расхода материала - это "количество" у компонента "материал" в коллекции "техпроцесс".
Параметры материала (заготовки) - это параметры компонента "материал" в коллекции "техпроцесс".

Вот с этими объектами и оперируйте.

Мы в своих плагинах, поскольку техпроцессов у детали может быть много и материалов в каждом техпроцессе может быть много, дополнительно выделяем такую сущность, как "основной материал" детали. Технически для этого соответствующий компонент (материал) из коллекции (техпроцесс) дополнительно привязывается, как связанный объект, к номенклатуре детали.
 
От детали (из номенклатуры )берем ID,в коллекции компонентов по(id детали)=ovnerid,находим id-(тех проц.),в компонентах по ovnerid=(id тех проц.)находим nomenclatureid -(материал) ...и.т.д,так представляю...а как реализовать?
 
Cписок коллекций по номенклатуре:
Код
var collections = ExtensibleApplication.Application.General.ComponentCollections(nomenclatureId)

Список компонентов коллекции:
Код
var comps = ExtensibleApplication.Application.General.Components(collectionId)

Поиск по спискам:
Код
var searchResult = bizObjectList.QuickSearch(new[]{"Имя свойства"}, new object[]{значение})
 
Например, есть ID номенклатуры у которой одна коллекция. В этой коллекции нам надо найти компонент с типом связи материал и поменять ему количество.

Код
var collections = ExtensibleApplication.Application.General.ComponentCollections(nomenclatureId);
var collectionId = collections[0].Id.AsLongInt; 
var comps = ExtensibleApplication.Application.General.Components(collectionId);
var searchResult = comps.QuickSearch(new[]{"LinkTypeUID"}, new object[]{"LT_Material"});
var mat = searchResult[0];
try
{
mat["Quantity"].Value = 123;
mat.Save();
}
finally
{
mat.Cancel();
}
 
Спасибо,так и пытаюсь собирать...
 
Большое всем СПАСИБО кнопка получилась отличная (норма матер,и сварку и краску  считает!!! все как и задумал)
.....беспокоит один вопрос что после ID 999999 ?
 
Цитата
что после ID 999999
ID 1000000  :)
 
тогда поместится все...
 
Код
Добавляем параметр так: 
1. получаете параметры нужного объекта(номенклатуры, компонента, коллекции...) 
2. создаёте новый параметр 
3. изменяете необходимые значения 
4. сохраняете и т.д...

Подскажите,пожалуйста, как такой же фокус проделать с папкой в дереве номенклатуры...
-выбираем номенклатурную поз.(-> piugin)
-добавляет папку в текущую папку номенклатуры с наименованием номенклатурной поз...(хочу упростить создание дерева номенклатуры для изделий, (сбор ед 1, входящие сборки и детали помещаем в папку с названием сбор ед 1, и т.д, )
 
Берём папки:
Код
var folders = ExtApp.Application.General.Folders(categoryId);

Создаём новую:
Код
var newFolder = folders.AddNew();
try
{
 newFolder.Name.Value = "новая папка";
 newFolder.ParentID.Value = folderId;//родительская папка
 newFolder.Save();
}
finally
{
 newFolder.Cancel();
}

Помещаем номенклатуру в папку:
Код
var nmk = nomenclatureItem as ArrangedObject;
try
{
 nmk["FolderId"].AsLongInt = folder.ID.AsLongInt;
 nmk.Save();
}
finally
{
 nmk.Cancel()
}
 
Здравствуйте , ув. разработчики.

Интересует вопрос , как сделать кнопку , нажатие на которую открывало бы окно создания новой папки , после создавалась эта папка ( с название которое ввели ) и в ней же находилось две дочерних папки ( к примеру с названиями Узлы и Детали ) .

И скажите пожалуйста как устанавливаются эти .dll файлы ( кинул в директорию программы, но кнопка не появилась )
Снимок.PNG (15.04 КБ)
Снимок1.PNG (3.05 КБ)
Изменено: Максим Прохоров - 08.09.2014 10:22:43
ООО "Нефтезаводмонтаж" , г.Волгоград
 
Всё тоже самое: создаёте папку
Код
var newFolder = folders.AddNew();
newFolder.ParentID.Value = folderId;//родительская папка
Создаёте диалог
Код
var folderDialog = new NodeEditForm(ExtApp);
в диалог подсовываете создаваемую папку
Код
folderDialog.DataSource = newFolder;
Показываете диалог, и если нажат ОК - сохраняете:
Код
if (folderDialog.ShowDialog() == PlugInFormShowResult.Ok)
            {               
                newFolder.Save();
            }
            else newFolder.Cancel();
Дальше создаёте новые папки "Узлы" и "Детали" с ParentId равным id newFolder'a
Цитата
Максим Прохоров пишет:
И скажите пожалуйста как устанавливаются эти .dll файлы ( кинул в директорию программы, но кнопка не появилась )
достаточно кинуть файлы в директорию программы. Если не появилась, то возможно кнопка скрыта - поищите в настройках панели инструментов. Если и там нет - значит что-то сделали не так
 
Спасибо, Сергей
ООО "Нефтезаводмонтаж" , г.Волгоград
 
Если я правильно понял, то код создания двух папок будет следующим ... в комментарий почему то не получается добавить его. Парсер не пропускает ...
Изменено: Максим Прохоров - 14.09.2014 18:37:21
ООО "Нефтезаводмонтаж" , г.Волгоград
 
Цитата
Максим Прохоров пишет:
Если я правильно понял, то код создания двух папок будет следующим ...
Код
var newFolder = folders.AddNew();
newFolder.Name.Value = "Узлы";
newFolder.ParentID.Value = newFolderId;
newFolder.Name.Value = "Детали";
newFolder.ParentID.Value = newFolderId;
Нет. Поняли не правильно. В вашем коде создаётся одна папка(AddNew). Затем одной и той же папке два раза присваивается разное наименование и 2 раза указывается родитель в дереве. +отсутствует сохранение.
Посмотрите сообщение №43 в этой теме. Там практически готовая функция для создания папок по названию и родителю.
 
Сергей! Сделал плагин, который загружает номенклатуру в Вогбит из файла .csv. Загрузку проходит нормально, но при повторной загрузке вылетает ошибка, что такая номенклатура есть. Пытаюсь организовать поиск в справочнике ранее загруженной номенклатуры, но что-то делаю не так. Подскажите где ошибка:
           try
           {
               using (StreamReader sr = new StreamReader(@"D:\nmkFile.csv", Encoding.Default))
               {
                   string[] headers = sr.ReadLine().Split('\t');
                   var folderId = ((IPlugInForm)activeForm).FormParams["FolderId"].AsLongInt;
                   var nmks = ExtApp.Application.General.Nomenclature(folderId, CatalogOptions.None);
                   foreach (string header in headers)
                   {
                       string strk = "";
                       while (!sr.EndOfStream)
                       {
                           string[] rows = sr.ReadLine().Split('\t');

                          /////Здесь бы нужен поиск по QuickSearch и в случае успеха номенклатуру не грузить
                           var searchResult = nmks.QuickSearch(new[] { "Name" }, new object[] { "ObjectNomenclature" });
                           ((ObjectNomenclature)searchResult[0]).NomenclatureValue;
                          ////////////////////////////////////////////////////////////­///////////////

                           var nmk = nmks.AddNew();
                           for (int i = 0; i < headers.Length; i++)
                           {
                               if (i == 0 && strk != rows[i])
                               {
                                   strk = rows[i];
                                   //Здесь можно добавить заказ
                               }
                               if (i == 2)
                               {
                                   nmk.Notation.Value = rows[i];
                               }
                               if (i == 1)
                               {
                                   nmk.Name.Value = rows[i];
                               }
                           }
                           nmk.Save();
                       }
                   }
               }
           }
           finally
           {
               //activeForm.Cancel();
           }
 
1. Обозначение номенклатуры должно быть уникально в рамках всей базы. Наименования могут быть одинаковыми. Соответственно, в поиске надо проверять Notation. Либо по наименованию(в случае если обозначение отсутствует). Это зависит от того, как у вас номенклатурный справочник ведётся. Ещё может быть случай, что обозначение совпадает, а наименование - нет.
2. В приведённом коде поиск производится в конкретной папке. Не факт, что уже существующая номенклатура лежит в этой папке.

В общем случае поиск номенклатуры по обозначению может выглядеть так:
Код
var nmks = ExtApp.Application.General.Nomenclature(-1, CatalogOptions.None);//беру весь справочник номенклатуры
......
var nmkNotation = rows[2];//обозначение номенклатуры из файла
var searchResult = nmks.QuickSearch(new[] { "Notation" }, new object[] { nmkNotation });//для наименования соответственно "Name" и rows[1]
if(searchResult != null && searchResult.Any())
{
//есть такая номенклатура
}

Есть ещё вариант поиска объекта по обозначению. Надо только тип объекта указать.
Код
ExtApp.Application.General.GetObjectByNotation()

Ну и можно ещё обрабатывать исключение при сохранении номенклатуры
Код
catch (SqlServerException exception)
{
   if (exception.Code == ErrorCode.NoteNotUnique)
   {
      //обозначение не уникально
   }
}
 
Реализовал первый вариант поиска, но если во втором варианте можно делать поиск объекта по обозначению любого типа, то где здесь указать тип объекта?

ExtApp.Application.General.GetObjectByNotation()

Потребуется поиск папок, заказов на производство, параметров. Второй вариант подойдет для этих целей?

Посмотрел, также базовые объекты по F11, но поле типа объекта там пустое и не очень понятно где ставить тип объекта, как он выглядит. Да и кнопку настройки не вижу в меню, чтобы сконфигурировать интерфейс.
 
Цитата
Николай Спирин написал:
где здесь указать тип объекта?
Второй параметр:
Код
ExtApp.Application.General.GetObjectByNotation(nmkNotation, (long)SystemObjectTypes.Nomenclature);
Цитата
Николай Спирин написал:
Второй вариант подойдет для этих целей?
Смотря как ведёте справочники. Обозначения может и не быть. Параметры в справочнике искать - подойдёт, параметры объекта искать - не подойдёт. Первый способ более гибкий.

Цитата
Николай Спирин написал:
поле типа объекта там пустое
Встаньте на ID. Или FolderID. Или любое другое Свойство-Идентификатор. Покажет какого типа объект с таким идентификатором.

Цитата
Николай Спирин написал:
кнопку настройки не вижу в меню, чтобы сконфигурировать интерфейс
здесь
 
Сергей! В общем загрузка номенклатуры и поиск ее для проверки получился. Но грузить и искать номенклатуру нужно будет с учетом папок и вместе с заказами на производство. Кроме того к каждой номенклатуре должен быть прикреплен техпроцесс, который должен быть создан сам заранее и все материалы загружены заранее, а потом должен как-то сопоставлен с номенклатурой изделия. Для таких загрузок с иерархией был бы  удобен формат json. В литературе пишут, что должна быть подключена дополнительная библиотека. Подскажите какая лучше подойдет для Вогбита, или ели есть выложите пример загрузки-выгрузки данных в этом формате.
 
Цитата
Николай Спирин написал:
каждой номенклатуре должен быть прикреплен техпроцесс, который должен быть создан сам заранее и все материалы загружены заранее, а потом должен как-то сопоставлен с номенклатурой изделия. Для таких загрузок с иерархией был бы  удобен формат json.
Вставлю пять копеек...

Тут дело не в формате.
А в том, что номенклатурная позиция одна отдельно взятая и данные для производства - это как-бы небо и земля.
Номенклатура - тут всё элементарно. Запись одна в справочнике. Поискали, есть - хорошо, нет - добавили запись новую. Всё, конец.

А если взять, например, техпроцесс, то это совсем другого порядка песня.
Это коллекция, в ней компоненты, параметры со значениями, связанные объекты с определёнными типами связей, связанные объекты с тем, на основе чего созданы компоненты.
И это только одна деталь.
В заказе в вашем случае таких десятки.
+ есть узлы.
Есть спецификации "конструкторские" и "заказные".
Есть связи между "операциями".
И всё это вместе представляет собой данные, чтобы потом одной кнопкой в производстве получались нужные задания, в разных случаях они правильно обрабатывались, где нужно работы объединялись в одно задание, где не нужно, чтобы не объединялись, чтобы по мере выполнения одной группы заданий предлагалась для выдачи следующая группа и т.д.

В общем, такую конструкцию из данных правильно соорудить - это совсем не одну запись найти - добавить...
В самом VOGBIT есть плагины специальные, в них прописана логика на всевозможные случаи. Как когда что заполнять, что с чем связывать.
Благодаря этому для пользователя всё легко и просто. Мышкой перетащил строчку из одного окошка в другое, и всё само создалось, связалось, думать не нужно, как там что внутри устроено.
А "генератор" так и вообще при определённой настойке сам, автоматически, всё это создаёт, заполняет, находит что нужно и использует, что нужно создаёт...
Эта часть программы внутри совсем не тривиальная.

Так вот.
Если вы хотите зачем-то это всё дело (не только номенклатуру, но и спецификации, техпроцессы) из VOGBIT читать, то это, в общем, не сложно. Берите, считывайте, сохраняйте в файл. Какого хотите формата.
Если же вы хотите это снаружи в VOGBIT зачем-то создавать, то тут, мягко говоря, вам работы надолго хватит. Очень надолго...
И, главное, непонятно зачем.
Намного проще в самом VOGBIT создавать то, что ему нужно для работы (техпроцессы те же). Он прекрасно это умеет. Это намного легче будет, чем программно снаружи пытаться соорудить то же самое в базе. Быстрее и легче просто будет эти техпроцессы в самом VOGBIT и сделать. Даже вручную, думаю. Не говоря уже о том, если "генератором".
В общем смысл в вашем конкретном случае создавать ТП в VOGBIT программой снаружи мне просто не понятен.
Но так-то дело ваше... Хотите, есть время и желание - изучайте, создавайте. Ничего невозможного нет. Просто придётся изучать, как это всё устроено, писать кучу кода, тестировать это потом всё на пригодность.
Хотите? Занимайтесь))
Изучайте. Начать вот с этого можно...

А формат файла какой - json, xml, самодельный какой-нибудь - это 25-й вопрос в данном случае. Какая разница из какого формата данные читать (писать в него). Вопрос в том, что и как делать с тем, что считал из файла - вот где тут 99 процентов, собственно, кроется. А формат файла то без разницы какой, по большому счёту.
 
В .NET есть "свои" средства для работы с JSON. Из сторонних можно ньютонсофт посмотреть. Вогбиту без разницы. Создание\изменение объектов всё равно придётся ручками прописывать. Ну и как сказано выше, цель всего этого мероприятия не очень понятна.
 
Сергей, я не точно выразился, техпроцесс не должен создаваться сам, тем более в Вогбите есть генератор ТП. Достаточно найти номенклатуру изделия с которой связан свой техпроцесс, а если номенклатура не найдена, то добавить ее и потом к ней сгенерировать техпроцесс, или, если это возможно, идентифицировать уже существующий техпроцесс как коллекцию с компонентами и связать его с новой номенклатурой. В примере подробного описания техпроцесса видно, что изделие Кронштейн связан с ТП1. Возможно эту связь один раз можно установить программно или вручную или наконец сгенерировать для новой номенклатуры новый техпроцесс, а потом пользоваться этой связкой при загрузке Заказа на производстве со своим списком номенклатуры изделий.

[img][/img]
 
Сергей! Все таки, возможно загруженную или созданную новую номенклатурную позицию связать один раз вручную или программно с существующим техпроцессом или даже потом вручную сгенерировать к этой номенклатуре новый техпроцесс? А потом пользоваться этой связкой при последующих загрузках.
 
"Сгенерировать" техпроцесс к уже существующей номенклатуре нельзя. "Генератор" на основании "шаблона" создаёт новую номенклатуру и к ней сам заполняет всё, что нужно.

"Приделать" существующий техпроцесс от одной номенклатуры (ТП не может существовать "оторванный" вообще от номенклатуры, это коллекция, а у коллекции в любом случае есть owner (номенклатура)) к другой номенклатуре - технически возможно, но я бы настоятельно не рекомендовал этого делать. Помимо техпроцесса там ещё много чего есть. Спецификации, в частности, и параметры. Кроме того, есть всё таки разница между "родной" коллекцией компонентов и "связанной" (приделанной от другой номенклатуры), и я не поручусь на 100% процентов, что на "связанных" коллекциях всё и во всех местах будет потом правильно работать.
В общем, я бы так делать не стал.

И в первом, и во втором случае намного проще взять "нормальную" номенклатуру, правильно созданную "генератором", и просто её переименовать. Если Вам хочется, чтобы она по другому называлась как-то.
 
Остается одно. Созданную номенклатуру вместе с id выгрузить в 1С, там ее сопоставить с номенклатурой 1С и выгружать вместе с id в Вогбит. Но техпроцесс то можно, наверное, создать в Вогбит программно и присвоить ему номер из 1С, а потом заполнить его номенклатурой найденной по id?
Страницы: Пред. 1 2
Сейчас на форуме (гостей: 18)
Всего зарегистрированных пользователей: 3072
Приняло участие в обсуждении: 355
Всего тем: 804
Всего сообщений: 6067

Полезные ссылки:
Видео-презентация Себестоимость подготовка производства Начало работы технологическая подготовка Расчёт комплектации производственный учет Складской учёт складской учет управление данными ТПП Демонстрационный режим VOGBIT электронный архив Обновление VOGBIT График производства управление качеством Полная версия VOGBIT Создание новой базы данных VOGBIT Планирование мелкосерийного производства управление производством Техническая Подготовка Производства деактивации VOGBIT активация VOGBIT управление ремонтами планирование производства инструкция Производственный заказ Установка VOGBIT загрузка оборудования расчет себестоимости Трудоёмкость базы данных VOGBIT Деактивация VOGBIT Генератор отчетов производство металлоконструкций Сменное задание пост руководство администраторов VOGBIT Задания для производства разработчика отчетов vogbit Тип нормирования состав изделия Нормирование Заказ на производство технология Планирование производства демоверсия Состав изделия Обзор обновления склад Интерфейс Цеховой терминал для участков ЧПУ подключение нового шаблона отчёта План производства в виде диаграммы Гантта улучшения Расчёт цены
×
Вход на сайт