Перейти к содержимому
Odoo Меню
  • Войти
  • Попробовать бесплатно
  • Модули
    Финансы
    • Бухгалтерия
    • Выставление счетов
    • Расходы
    • Таблицы
    • Документооборот
    • Подпись
    Продажи
    • CRM
    • Продажи
    • POS Магазин
    • POS Ресторан
    • Подписки
    • Аренда
    Вебсайты
    • Конструктор вебсайтов
    • eCommerce
    • Блог
    • Форум
    • Онлайн-чат
    • Электронное обучение
    Логистика
    • Склад
    • Производство
    • PLM
    • Закупки
    • Обслуживание
    • Качество
    Отдел кадров
    • Сотрудники
    • Подбор персонала
    • Отпуска
    • Оценка персонала
    • Реферальная программа
    • Автопарк
    Маркетинг
    • SMM
    • E-mail рассылки
    • СМС рассылки
    • Мероприятия
    • Автоматизация маркетинга
    • Опросы
    Услуги
    • Проекты
    • Табели
    • Выездной сервис
    • Поддержка
    • Планирование
    • Встречи
    Продуктивность
    • Обсуждения
    • Согласование
    • IoT
    • VoIP-телефония
    • Knowledge
    • WhatsApp
    Сторонние приложения Модуль Студия Odoo Платформа Odoo Cloud
  • Индустрии
    Розничная торговля
    • Книжный магазин
    • Магазин одежды
    • Мебельный магазин
    • Продуктовый магазин
    • Строительный магазин
    • Магазин игрушек
    Гостинично-ресторанный бизнес
    • Бар и паб
    • Ресторан
    • Фастфуд
    • Гостевой дом
    • Дистрибьютор напитков
    • Отель
    Недвижимость
    • Агентство недвижимости
    • Архитектурное бюро
    • Строительство
    • Управление недвижимостью
    • Ландшафтный дизайн
    • Товарищество собственников жилья
    Консалтинг
    • Бухгалтерская фирма
    • Партнер Odoo
    • Маркетинговое агентство
    • Юридическая фирма
    • Подбор персонала
    • Аудиторское бюро
    Производство
    • Текстиль
    • Металл
    • Мебель
    • Продукты питания
    • Пивоварня
    • Корпоративные сувениры
    Здоровье и фитнес
    • Спортивный комплекс
    • Магазин оптики
    • Фитнес-клуб
    • Велнес-центр
    • Аптека
    • Салон красоты
    Услуги
    • Специалист по бытовым услугам
    • Продажа и обслуживание IT-оборудования
    • Солнечные энергосистемы
    • Производство обуви
    • Клининг
    • Системы ОВКВ
    Прочее
    • Некоммерческая организация
    • Консалтинг в сфере устойчивого развития
    • Аренда рекламных щитов
    • Бизнес по фотосъемке
    • Прокат велосипедов
    • Реселлер программного обеспечения
    Все индустрии
  • Community
    Обучение
    • Видео уроки
    • Документация
    • Сертификация
    • Тренинг
    • Блог
    • Подкаст
    Образование и развитие
    • Образовательная программа
    • Деловая игра Scale Up!
    • Экскурсия в офис Odoo
    ПО
    • Скачать
    • Сравнить версии
    • Релизы
    Сотрудничество
    • Github
    • Форум
    • Мероприятия
    • Перевод
    • Стать партнером
    • Услуги для партнеров
    • Зарегистрировать бухгалтерскую фирму
    Услуги
    • Найти партнера
    • Найти бухгалтера
    • Встреча с экспертом
    • Услуги по внедрению
    • Отзывы клиентов
    • Поддержка
    • Обновления
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Заказать демонстрацию
  • Цены
  • Поддержка

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Бухгалтерия
  • Склад
  • PoS
  • Проекты
  • MRP
All apps
Чтобы взаимодействовать с сообществом, необходимо зарегистрироваться.
Все посты Люди Значки
Теги (Смотреть все)
odoo accounting v14 pos v15
Об этом форуме
Чтобы взаимодействовать с сообществом, необходимо зарегистрироваться.
Все посты Люди Значки
Теги (Смотреть все)
odoo accounting v14 pos v15
Об этом форуме
Помощь

wizard_payment_order('populate_payment_ext') TypeError: __new__() takes exactly 1 argument (2 given)

Подписаться

Получайте уведомления о появлении активности в этом посте

Этот вопрос был отмечен
posaccount
1 Ответить
6562 Представления
Аватар
sridhar

I Tried to Install account_payment_extension it is open source module developed for 6.x version. But now i try to install on OpenERP 7, but it making error, i got this error wizard_payment_order('populate_payment_ext') TypeError: __new__() takes exactly 1 argument (2 given), previously i faced the error that is ImportError: No module named wizard then i change hide the import wizard and class wizard_payment_order(osv.TransientModel): here is my code #import wizard import pooler from tools.misc import UpdateableStr import time from osv import fields, osv

FORM = UpdateableStr()

FIELDS = { 'entries': {'string':'Entries', 'type':'many2many', 'relation':'account.move.line',}, 'communication2': {'string':'Communication 2', 'type':'char', 'size': 64, 'help':'The successor message of payment communication.'}, }

field_duedate={ 'duedate': {'string':'Due Date', 'type':'date','required':True, 'default': lambda *a: time.strftime('%Y-%m-%d'),}, 'amount': {'string':'Amount', 'type':'float', 'help': 'Next step will automatically select payments up to this amount as long as account moves have bank account if that is required by the selected payment mode.'}, 'show_refunds': {'string':'Show Refunds','type':'boolean', 'help':'Indicates if search should include refunds.', 'default': lambda *a: False}, } arch_duedate=''' <form string="Search Payment lines" col="2"> <field name="duedate"/> <field name="amount"/> <field name="show_refunds"/> </form>'''

def search_entries(self, cr, uid, data, context): search_due_date = data['form']['duedate'] show_refunds = data['form']['show_refunds']

pool = pooler.get_pool(cr.dbname)
order_obj = pool.get('payment.order')
line_obj = pool.get('account.move.line')

payment = order_obj.browse(cr, uid, data['id'],
        context=context)
ctx = ''
if payment.mode:
    ctx = '''context="{'journal_id': %d}"''' % payment.mode.journal.id

# Search for move line to pay:
domain = [('reconcile_id', '=', False),('account_id.type', '=', payment.type),('amount_to_pay', '<>', 0)]

if payment.type =='payable' and not show_refunds:
    domain += [ ('credit','>',0) ]
elif not show_refunds:
    domain += [ ('debit','>',0) ]

if payment.mode:
    domain += [('payment_type','=',payment.mode.type.id)]

domain += ['|',('date_maturity','<',search_due_date),('date_maturity','=',False)]
line_ids = line_obj.search(cr, uid, domain, order='date_maturity', context=context)


FORM.string = '''<?xml version="1.0" encoding="utf-8"?>

<form string="Populate Payment:"> <field name="entries" colspan="4" height="300" width="800" nolabel="1" domain="[('id', 'in', [%s])]" %s=""/> <separator string="Extra message of payment communication" colspan="4"/> <field name="communication2" colspan="4"/> </form>''' % (','.join([str(x) for x in line_ids]), ctx)

selected_ids = []

amount = data['form']['amount']
if amount:
    if payment.mode and payment.mode.require_bank_account:
        line2bank = line_obj.line2bank(cr, uid, line_ids, payment.mode.id, context)
    else:
        line2bank = None
    # If user specified an amount, search what moves match the criteria taking into account
    # if payment mode allows bank account to be null.
    for line in line_obj.browse(cr, uid, line_ids, context):
        if abs(line.amount_to_pay) <= amount:
            amount -= abs(line.amount_to_pay)
            selected_ids.append( line.id )
else:
    selected_ids = line_ids

return {
    'entries': selected_ids,
}

def create_payment(self, cr, uid, data, context): line_ids= data['form']['entries'][0][2] if not line_ids: return {}

pool= pooler.get_pool(cr.dbname)
order_obj = pool.get('payment.order')
line_obj = pool.get('account.move.line')

payment = order_obj.browse(cr, uid, data['id'],
        context=context)
t = payment.mode and payment.mode.type.id or None
line2bank = pool.get('account.move.line').line2bank(cr, uid,
        line_ids, t, context)

## Finally populate the current payment with new lines:
for line in line_obj.browse(cr, uid, line_ids, context=context):
    if payment.date_prefered == "now":
        #no payment date => immediate payment
        date_to_pay = False
    elif payment.date_prefered == 'due':
        date_to_pay = line.date_maturity
    elif payment.date_prefered == 'fixed':
        date_to_pay = payment.date_scheduled

    if payment.type == 'payable':
        amount_to_pay = line.amount_to_pay
    else:
        amount_to_pay = -line.amount_to_pay
    pool.get('payment.line').create(cr,uid,{
        'move_line_id': line.id,
        'amount_currency': amount_to_pay,
        'bank_id': line2bank.get(line.id),
        'order_id': payment.id,
        'partner_id': line.partner_id and line.partner_id.id or False,
        'communication': (line.ref and line.name!='/' and line.ref+'. '+line.name) or line.ref or line.name or '/',
        'communication2': data['form']['communication2'],
        'date': date_to_pay,
        'currency': line.invoice and line.invoice.currency_id.id or False,
        'account_id': line.account_id.id,
        }, context=context)
return {}

class wizard_payment_order(osv.TransientModel): """ Create a payment object with lines corresponding to the account move line to pay according to the date provided by the user and the mode-type payment of the order. Hypothesis: - Small number of non-reconcilied move line , payment mode and bank account type, - Big number of partner and bank account.

If a type is given, unsuitable account move lines are ignored.
"""
states = {

    'init': {
        'actions': [],
        'result': {
            'type': 'form',
            'arch': arch_duedate,
            'fields':field_duedate,
            'state': [
                ('end','_Cancel'),
                ('search','_Search', '', True)
            ]
        },
     },

    'search': {
        'actions': [search_entries],
        'result': {
            'type': 'form',
            'arch': FORM,
            'fields': FIELDS,
            'state': [
                ('end','_Cancel'),
                ('create','_Add to payment order', '', True)
            ]
        },
     },
    'create': {
        'actions': [],
        'result': {
            'type': 'action',
            'action': create_payment,
            'state': 'end'}
        },
    }

wizard_payment_order('populate_payment_ext') Please help me i struggled here.

Thanks& Regards Sridharan G

0
Аватар
Отменить
Аватар
Sudhir Arya (ERP Harbor Consulting Services)
Лучший ответ

Just changing wizard.interface into osv.TransientModel won't work. You have to convert it just like all other wizards (memory wizards) available in v7.

My answer (Convert interface into memory wizard) could help you to convert it.

1
Аватар
Отменить
sridhar
Автор

This Wizard dont having a .XML file then where i paste this code my_form = <?xml version="1.0"?> <form string="Category Summary"> <group colspan="4"> <button name="check" type="object"/> </group> </form>

Sudhir Arya (ERP Harbor Consulting Services)

You have to create xml file and have to copy past the view related code.

sridhar
Автор

i don't have interface.py file wat to do. i'm new for openerp, so tuff to understand please help me...

Sudhir Arya (ERP Harbor Consulting Services)

You have to convert your current py file.

sridhar
Автор

It is tuf to understand send me a sample module please...

Не оставайтесь в стороне – присоединяйтесь к обсуждению!

Создайте аккаунт сегодня, чтобы получить доступ к эксклюзивным функциям и стать частью нашего замечательного сообщества!

Регистрация
Похожие посты Ответы Просмотры Активность
POS: Setting some payment methods to not mark invoice as paid
sales pos account
Аватар
0
дек. 15
3647
POS sales to analytic account
pos account analytic
Аватар
0
мар. 15
4748
Kitchen printing printer other than odoo provided list
pos
Аватар
Аватар
1
нояб. 25
245
POS Table Synchronization Issue Between Devices in Odoo v17 CE
pos
Аватар
Аватар
Аватар
2
нояб. 25
2647
Refund and Discount access to admin user only for Pos selling
pos
Аватар
Аватар
1
нояб. 25
467
Сообщество
  • Видео уроки
  • Документация
  • Форум
Открытый исходный код
  • Скачать
  • Github
  • Runbot
  • Перевод
Услуги
  • Хостинг Odoo.sh
  • Поддержка
  • Обновление
  • Индивидуальные решения по доработке
  • Образование
  • Найти бухгалтера
  • Найти партнера
  • Стать партнером
О нас
  • Наша компания
  • Активы бренда
  • Cвяжитесь с нами
  • Вакансии
  • Мероприятия
  • Подкаст
  • Блог
  • Клиенты
  • Правовые документы • Конфиденциальность
  • Безопасность
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo – это набор бизнес-модулей с открытым исходным кодом, который закроет все потребности вашей компании: CRM, E-commerce, Бухгалтерия, Склад, POS, управление проектами и др.

Odoo сочетает в себе простоту использования и полную интеграцию всех бизнес-процессов в одной системе.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now