forked from Yaltik/golem
[REF][IMP]GOLEM analysis : add flexibility
* On get members ; * On get registrations and use it for state addon.
This commit is contained in:
parent
1c3f10ad0a
commit
4898a0d93d
@ -65,14 +65,21 @@ class GolemActivityRegistrationAnalysisWizard(models.TransientModel):
|
|||||||
'golem_member_analysis_pivot_age_now_activity_area')
|
'golem_member_analysis_pivot_age_now_activity_area')
|
||||||
return self.env.ref(ref, False)
|
return self.env.ref(ref, False)
|
||||||
|
|
||||||
|
@api.multi
|
||||||
|
def get_registrations(self):
|
||||||
|
""" Returns registrations """
|
||||||
|
self.ensure_one()
|
||||||
|
return self.env['golem.activity.registration'].search(
|
||||||
|
[('season_id', '=', self[0].season_id.id)]
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
@api.multi
|
@api.multi
|
||||||
def registration_analyse(self):
|
def registration_analyse(self):
|
||||||
""" registration analyse """
|
""" registration analyse """
|
||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
analysis_rec = self[0]
|
analysis_rec = self[0]
|
||||||
registrations = self.env['golem.activity.registration'].search(
|
registrations = analysis_rec.get_registrations()
|
||||||
[('season_id', '=', analysis_rec.season_id.id)]
|
|
||||||
)
|
|
||||||
if registrations:
|
if registrations:
|
||||||
for registration in registrations:
|
for registration in registrations:
|
||||||
self.env['golem.member.analysis'].create({
|
self.env['golem.member.analysis'].create({
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
# Copyright 2017-2018 Fabien Bourgeois <fabien@yaltik.com>
|
# Copyright 2017-2019 Fabien Bourgeois <fabien@yaltik.com>
|
||||||
#
|
#
|
||||||
# This program is free software: you can redistribute it and/or modify
|
# This program is free software: you can redistribute it and/or modify
|
||||||
# it under the terms of the GNU Affero General Public License as
|
# it under the terms of the GNU Affero General Public License as
|
||||||
@ -19,7 +19,7 @@
|
|||||||
'name': 'GOLEM Activity Session Member Registrations States',
|
'name': 'GOLEM Activity Session Member Registrations States',
|
||||||
'summary': 'GOLEM Activities Session Member Registration states',
|
'summary': 'GOLEM Activities Session Member Registration states',
|
||||||
'description': 'GOLEM Activities Session Member Registration states',
|
'description': 'GOLEM Activities Session Member Registration states',
|
||||||
'version': '10.0.2.2.1',
|
'version': '10.0.2.3.0',
|
||||||
'category': 'GOLEM',
|
'category': 'GOLEM',
|
||||||
'author': 'Fabien Bourgeois',
|
'author': 'Fabien Bourgeois',
|
||||||
'license': 'AGPL-3',
|
'license': 'AGPL-3',
|
||||||
|
@ -18,9 +18,7 @@
|
|||||||
|
|
||||||
""" GOLEM Activity Registration Analysis Wizard Adaptation """
|
""" GOLEM Activity Registration Analysis Wizard Adaptation """
|
||||||
|
|
||||||
import logging
|
from odoo import models, fields, api
|
||||||
from odoo import models, fields, api, _
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
|
||||||
|
|
||||||
|
|
||||||
class GolemActivityRegistrationAnalysisWizard(models.TransientModel):
|
class GolemActivityRegistrationAnalysisWizard(models.TransientModel):
|
||||||
@ -29,30 +27,10 @@ class GolemActivityRegistrationAnalysisWizard(models.TransientModel):
|
|||||||
_description = 'GOLEM Activity Registration Analysis Wizard Adaptation '
|
_description = 'GOLEM Activity Registration Analysis Wizard Adaptation '
|
||||||
|
|
||||||
@api.multi
|
@api.multi
|
||||||
def registration_analye(self):
|
def get_registrations(self):
|
||||||
""" registration analyse """
|
""" Returns registrations """
|
||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
analysis_rec = self[0]
|
return self.env['golem.activity.registration'].search(
|
||||||
registrations = self.env['golem.activity.registration'].search(
|
[('season_id', '=', self[0].season_id.id),
|
||||||
[('season_id', '=', analysis_rec.season_id.id),
|
|
||||||
('state', '=', 'confirmed')]
|
('state', '=', 'confirmed')]
|
||||||
)
|
)
|
||||||
self.env['golem.member.analysis'].search([]).unlink()
|
|
||||||
if registrations:
|
|
||||||
for registration in registrations:
|
|
||||||
self.env['golem.member.analysis'].create({
|
|
||||||
'season_id': analysis_rec.season_id.id,
|
|
||||||
'member_id': registration.member_id.id,
|
|
||||||
'activity_id': registration.activity_id.id
|
|
||||||
})
|
|
||||||
analyse_pivot = analysis_rec.get_pivot_view()
|
|
||||||
return {
|
|
||||||
'name': _('Member Analysis'),
|
|
||||||
'type': 'ir.actions.act_window',
|
|
||||||
'res_model': 'golem.member.analysis',
|
|
||||||
'view_type': 'pivot',
|
|
||||||
'view_mode': 'pivot',
|
|
||||||
#'views': [(analyse_pivot.id, 'form')],
|
|
||||||
'view_id': analyse_pivot.id,
|
|
||||||
'target': 'new',
|
|
||||||
}
|
|
||||||
|
@ -78,14 +78,20 @@ class GolemMemberAnalysis(models.TransientModel):
|
|||||||
return self.env.ref(ref, False)
|
return self.env.ref(ref, False)
|
||||||
|
|
||||||
|
|
||||||
|
@api.multi
|
||||||
|
def get_members(self):
|
||||||
|
""" Returns members """
|
||||||
|
self.ensure_one()
|
||||||
|
return self.env['golem.member'].search([]).filtered(
|
||||||
|
lambda m: self[0].season_id.id in m.season_ids.ids)
|
||||||
|
|
||||||
|
|
||||||
@api.multi
|
@api.multi
|
||||||
def members_analyse(self):
|
def members_analyse(self):
|
||||||
""" members analyse """
|
""" members analyse """
|
||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
analysis_rec = self[0]
|
analysis_rec = self[0]
|
||||||
members = self.env['golem.member'].search([]).filtered(
|
members = analysis_rec.get_members()
|
||||||
lambda m: analysis_rec.season_id.id in m.season_ids.ids)
|
|
||||||
if members:
|
if members:
|
||||||
for member in members:
|
for member in members:
|
||||||
self.env['golem.member.analysis'].create({
|
self.env['golem.member.analysis'].create({
|
||||||
|
Loading…
Reference in New Issue
Block a user