AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Функционал
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 14.05.2009, 09:40   #1  
KpecT is offline
KpecT
Участник
 
56 / 10 (1) +
Регистрация: 14.08.2007
Блокировка склада
Есть в системе ликвидированный склад. Необходимо сделать блокировку этого склада, т.е. пользователи немогли бы ни брать, ни ложить, ни производить остальные операции.
Подскажите может есть какие-то стандартные методы в Аксапте по блокированию склада?
Старый 14.05.2009, 10:46   #2  
Sada is offline
Sada
Программатор
Аватар для Sada
 
1,450 / 153 (8) ++++++
Регистрация: 29.03.2005
Адрес: Толи Барнаул, толи Москва
Инвентаризацию на нем провести может? Он по идее заблокируется. Или там номенклатура блокируется. Что то на вскидку не помню. Может номенклатура в соответствующих аналитиках заблокируется. Как то так.
Старый 14.05.2009, 11:09   #3  
Sada is offline
Sada
Программатор
Аватар для Sada
 
1,450 / 153 (8) ++++++
Регистрация: 29.03.2005
Адрес: Толи Барнаул, толи Москва
Можно завести каоай нить параметр в системе типа "блокированный склад" и немного докодить, чтоб по этому складу никаких физ операций низя было сделать. Но когда появиться такой второй склад - то это уже не выход. Заводить кучу таких параметров низя.
Старый 14.05.2009, 11:24   #4  
aidsua is offline
aidsua
AX*****
Аватар для aidsua
 
106 / 40 (2) +++
Регистрация: 28.09.2005
Адрес: 2:463/Kyiv
Цитата:
Сообщение от Sada Посмотреть сообщение
Инвентаризацию на нем провести может? Он по идее заблокируется. Или там номенклатура блокируется. Что то на вскидку не помню. Может номенклатура в соответствующих аналитиках заблокируется. Как то так.
Получится создавать строки в заказах.. вплоть до журналов прибытия и маршрутов комплектации.. единственное ограничение, которое работает при установленой галке "Блокировать номенклатуру при инвентаризации" в "Параметрах запасов" -- запретит закрывать маршруты/журналы прибытия. Т.е. в любом случае необходимо допиливать.
__________________
О, как беден, как груб наш русский язык! [c] А.С.Пушкин

Последний раз редактировалось aidsua; 14.05.2009 в 11:42.
Старый 14.05.2009, 11:31   #5  
Ivanhoe is offline
Ivanhoe
Участник
Аватар для Ivanhoe
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
 
4,143 / 2155 (80) +++++++++
Регистрация: 29.09.2005
Адрес: Санкт-Петербург
Цитата:
Сообщение от Sada Посмотреть сообщение
Можно завести каоай нить параметр в системе типа "блокированный склад" и немного докодить, чтоб по этому складу никаких физ операций низя было сделать. Но когда появиться такой второй склад - то это уже не выход. Заводить кучу таких параметров низя.
Тогда уж логичнее делать признак на складе...
А вообще, изначально была речь про СТАНДАРТ

Я в стандарте не знаю таких способов. Для отключения сводного планирования есть галка "Вручную".

Можно извратиться и настроить доступ на уровне записей, фильтровать доступные склады, например, по полю "Вид деятельности", а туда для старых складов писать что-нибудь а-ля "Заблокировано".
__________________
Ivanhoe as is..
Старый 14.05.2009, 11:43   #6  
mazzy is offline
mazzy
Участник
Аватар для mazzy
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
29,472 / 4494 (208) ++++++++++
Регистрация: 29.11.2001
Адрес: Москва
Записей в блоге: 10
Цитата:
Сообщение от KpecT Посмотреть сообщение
Есть в системе ликвидированный склад. Необходимо сделать блокировку этого склада, т.е. пользователи немогли бы ни брать, ни ложить, ни производить остальные операции.
Подскажите может есть какие-то стандартные методы в Аксапте по блокированию склада?
Нужно сделать три действия:
1. Включить галочку "Блокир. номенкл. при инвентаризации" в настройках управления запасами (см. скриншот)
2. В настройках номенклатур добавить строчки с этим складом в справочнике Местонахождение номенклатуры
3. Начать инвентаризацию номенклатур. Не завершать и не удалять ее пока склад заблокирован.

Обратите внимание, что этот способ блокирует не склад, а номенклатуры на складе.
См. Инвнтаризация по складской аналитике


Цитата:
Сообщение от Ivanhoe Посмотреть сообщение
Тогда уж логичнее делать признак на складе...
Не надо

Цитата:
Сообщение от Ivanhoe Посмотреть сообщение
Для отключения сводного планирования есть галка "Вручную".
Точно.
Миниатюры
Нажмите на изображение для увеличения
Название: 1.PNG
Просмотров: 506
Размер:	38.3 Кб
ID:	4632  
__________________
полезное на axForum, github, vk, coub.
Старый 14.05.2009, 11:48   #7  
mazzy is offline
mazzy
Участник
Аватар для mazzy
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
29,472 / 4494 (208) ++++++++++
Регистрация: 29.11.2001
Адрес: Москва
Записей в блоге: 10
Цитата:
Сообщение от aidsua Посмотреть сообщение
Получится создавать строки в заказах.. вплоть до журналов прибытия и маршрутов комплектации.. единственное ограничение, которое работает при установленой галке "Блокировать номенклатуру при инвентаризации" в "Параметрах запасов" -- запретит закрывать маршруты/журналы прибытия.
По заблокированной номенклатуре нельзя выполнить ни резервирование, ни физические, ни финансовые движения.

А журналы и заказы пусть создают.
Во-первых, ничего страшного в этом нет (особенно, если выключить сводное планирование по складу)
Во-вторых, у автора в требованиях не было ограничения на журналы/заказы
__________________
полезное на axForum, github, vk, coub.
Старый 14.05.2009, 11:59   #8  
aidsua is offline
aidsua
AX*****
Аватар для aidsua
 
106 / 40 (2) +++
Регистрация: 28.09.2005
Адрес: 2:463/Kyiv
Цитата:
Сообщение от mazzy Посмотреть сообщение
По заблокированной номенклатуре нельзя выполнить ни резервирование, ни физические, ни финансовые движения.

А журналы и заказы пусть создают.
Во-первых, ничего страшного в этом нет (особенно, если выключить сводное планирование по складу)
Во-вторых, у автора в требованиях не было ограничения на журналы/заказы
Только что проверил на DAX 4.0 SP1:
- Резервировать в "Заказе на продажу" позволяет
- "Маршрут комплектации" можно содать, активировать и начать, но не дает его завершить
- Комплектовать не разрешает

зы Доработок на приложении нет.
__________________
О, как беден, как груб наш русский язык! [c] А.С.Пушкин
За это сообщение автора поблагодарили: mazzy (2).
Старый 14.05.2009, 12:21   #9  
Ivanhoe is offline
Ivanhoe
Участник
Аватар для Ivanhoe
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
 
4,143 / 2155 (80) +++++++++
Регистрация: 29.09.2005
Адрес: Санкт-Петербург
Цитата:
Сообщение от mazzy Посмотреть сообщение
Нужно сделать три действия:
....
Обратите внимание, что этот способ блокирует не склад, а номенклатуры на складе.
См. Инвнтаризация по складской аналитике
Как это относится к исходной задаче? Нужно блокировать склад, а не номенклатуру. Что делать с новой номенклатурой?

Цитата:
Сообщение от mazzy Посмотреть сообщение
Цитата:
Сообщение от Ivanhoe
Тогда уж логичнее делать признак на складе...
Не надо
Если отойти от постановки вопроса (стандарт), то почему "не надо" признак на склад? Есть же примеры в плане счетов, фин. аналитике, клиентах, номенклатурах? В чем отличие?

Мне кажется, в системе должен быть достаточно универсальный (с точки зрения понятности для пользователя) механизм блокировки записей в справочниках. Идейно удалять "старые" записи неправильно, их нужно блокировать, но вот, почему-то, возможность блокировки есть не везде.
__________________
Ivanhoe as is..
Старый 14.05.2009, 12:23   #10  
KpecT is offline
KpecT
Участник
 
56 / 10 (1) +
Регистрация: 14.08.2007
А если номенклатура используется не на одном складе?
Старый 14.05.2009, 12:27   #11  
Ivanhoe is offline
Ivanhoe
Участник
Аватар для Ivanhoe
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
 
4,143 / 2155 (80) +++++++++
Регистрация: 29.09.2005
Адрес: Санкт-Петербург
Если сделать по шагам, как описал mazzy, то блокировка будет именно на том складе, который добавлен в Местонахождении номенклатуры.
P.S. галку "Инвентаризация начата" можно и руками поставить/снять.
__________________
Ivanhoe as is..

Последний раз редактировалось Ivanhoe; 14.05.2009 в 12:30.
Старый 14.05.2009, 12:30   #12  
Sada is offline
Sada
Программатор
Аватар для Sada
 
1,450 / 153 (8) ++++++
Регистрация: 29.03.2005
Адрес: Толи Барнаул, толи Москва
Ну вот... Механизм инвентаризации позволяет заблочить номенклатуры на складе, единственное с новыми номенклатурами косяк. Нужно допиливать. Думаю там не сложно.
Старый 14.05.2009, 15:07   #13  
in.dc is offline
in.dc
Участник
 
29 / 53 (2) ++++
Регистрация: 09.04.2009
Цитата:
Сообщение от KpecT Посмотреть сообщение
Есть в системе ликвидированный склад. Необходимо сделать блокировку этого склада, т.е. пользователи немогли бы ни брать, ни ложить, ни производить остальные операции.
Эквивалентно ли это ситуации, когда пользователи не могут 'выбрать' указанный склад в списке выбора (lookup)?
Если так, то возможно стоит обратить внимание на настройки безопасности на уровне записей (если есть лицензия на RLS) - создать группу, определить для нее условие RLS на таблице InventLocation (InventLocation.InventLocationId == !'ликвидированный склад') и добавить эту групу нужным пользователям?

P.S. этот вариант не поможет в случае если пользователи привыкли набивать коды складов 'руками' а не выбирать из списка доступных.
__________________
Dynamics AX 4.0 SP2
Старый 14.05.2009, 16:17   #14  
Alexius is offline
Alexius
Участник
Аватар для Alexius
 
461 / 248 (9) ++++++
Регистрация: 13.12.2001
Цитата:
Сообщение от in.dc Посмотреть сообщение
P.S. этот вариант не поможет в случае если пользователи привыкли набивать коды складов 'руками' а не выбирать из списка доступных.
Что-бы помогло - необходимо настроить RLS для всех используемых табличек, имеющих поля с типом InventLocationId ( AX 4.0 SP2).
Старый 14.05.2009, 17:29   #15  
petr is offline
petr
Участник
Соотечественники
 
557 / 201 (8) ++++++
Регистрация: 30.05.2005
Адрес: Швейцария
Если предложенные стандартные средства не подойдут, то я бы предложил следующее:

1. Галочка на InventLocation - признак "склад заблокирован"
2. Модифицировать форму InventLocationIdLookup, чтобы в лукап не попадали заблокированные склады.
3. В методе InventDim::findOrCreate(InventDim _inventDim) - приверять св-ов _inventDim.isFormDataSource() и если это дата сорс формы и склад заблокирован, сообщать об ошибке.
4. Проверить, работает ли этот подход, если встать на старый заказ (когда еще склад не был заблокирован) и нажать Ctrl+S. (Возможно еще придется проверить _inventDim.RecId == 0)
За это сообщение автора поблагодарили: KpecT (1).
Старый 14.05.2009, 19:13   #16  
sukhanchik is offline
sukhanchik
Administrator
Аватар для sukhanchik
MCBMSS
Злыдни
Лучший по профессии 2015
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,275 / 3476 (122) ++++++++++
Регистрация: 13.06.2004
Адрес: Москва
Цитата:
Сообщение от in.dc Посмотреть сообщение
этот вариант не поможет в случае если пользователи привыкли набивать коды складов 'руками' а не выбирать из списка доступных.
Это почемуй-то??? Если использовать именно RLS, а не что-то свое "типа RLS", то фильтрация накладывается на таблицу (в частности, InventDim) ДО ее использования (в т.ч. до открытия формы).
По крайней мере - с другими таблицами именно так и работает.
__________________
Возможно сделать все. Вопрос времени
Старый 15.05.2009, 10:11   #17  
Raven Melancholic is offline
Raven Melancholic
Участник
Аватар для Raven Melancholic
Самостоятельные клиенты AX
Лучший по профессии 2015
 
2,158 / 1286 (47) ++++++++
Регистрация: 21.03.2005
Адрес: Москва-Петушки
Если принимать подход с флагом блокировке на складе, то проверку логично делать в методе checkDimSearchFieldId таблицы InventDim. В большинстве случаев вызывается именно она (не напрямую, но в итоге проверки в ней). Все таки, на мой взгляд, findOrCreate для других целей.
За это сообщение автора поблагодарили: petr (1).
Старый 15.05.2009, 11:11   #18  
petr is offline
petr
Участник
Соотечественники
 
557 / 201 (8) ++++++
Регистрация: 30.05.2005
Адрес: Швейцария
Извините, если уклонился от функционала к программированию.

Цитата:
Сообщение от Raven Melancholic Посмотреть сообщение
Если принимать подход с флагом блокировке на складе, то проверку логично делать в методе checkDimSearchFieldId таблицы InventDim. В большинстве случаев вызывается именно она (не напрямую, но в итоге проверки в ней). Все таки, на мой взгляд, findOrCreate для других целей.
Для проверки при разноске согласен, но я не уверен, вызывается ли этот метод при создании закупки / заказа / строки журнала. А я так понимаю, если склад заблокирован, то логичнее сразу, еще при создании документа (черновика) сообщать пользователю о невозможности указать заблокированный класс.
Старый 15.05.2009, 11:24   #19  
petr is offline
petr
Участник
Соотечественники
 
557 / 201 (8) ++++++
Регистрация: 30.05.2005
Адрес: Швейцария
Еще немного подумал, наверное, надо править метод checkDimSearchFieldId таблицы InventDim, как предложил Raven Melancholic.
Старый 02.06.2009, 15:31   #20  
ortin is offline
ortin
Участник
 
39 / 11 (1) +
Регистрация: 10.09.2007
Адрес: СПб
А разве он вызывается при разноске? При создании и модификации - вызывается. При разноске - не отрабатывает. Чистого приложения для проверки под рукой нет.
Теги
блокировка номенклатуры, инвентаризация, склад

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Denis Fedotenko: Себестоимость и закрытие склада Blog bot DAX: База знаний и проекты 44 29.03.2010 14:54
Пополнение основного склада George V. Tavrizoff DAX: Функционал 4 20.03.2007 13:47
Финансовые проблемы при Закрытии склада Владимир Ю. DAX: Функционал 6 28.06.2005 20:00
Закрытие склада в основной и вторичной валюте, отключенная корреспонденция счетов May DAX: Функционал 1 02.04.2004 13:25
Бизнес-процессы склада в Аксапта Sirius DAX: Функционал 6 02.03.2004 18:52

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 21:19.
Powered by vBulletin® v3.8.5. Перевод: zCarot
Контактная информация, Реклама.