# -*- coding: utf-8 -*- # Part of Odoo. See LICENSE file for full copyright and licensing details. import operator from odoo.tools.float_utils import float_compare RATING_AVG_TOP = 3.66 RATING_AVG_OK = 2.33 RATING_AVG_MIN = 1 RATING_LIMIT_SATISFIED = 4 RATING_LIMIT_OK = 3 RATING_LIMIT_MIN = 1 RATING_HAPPY_VALUE = 5 RATING_NEUTRAL_VALUE = 3 RATING_UNHAPPY_VALUE = 1 RATING_NONE_VALUE = 0 RATING_TEXT = [ ('top', 'Happy'), ('ok', 'Neutral'), ('ko', 'Unhappy'), ('none', 'Not Rated yet'), ] OPERATOR_MAPPING = { 'in': lambda elem, container: elem in container, 'not in': lambda elem, container: elem not in container, '<': operator.lt, '<=': operator.le, '>': operator.gt, '>=': operator.ge, } def _rating_avg_to_text(rating_avg): if float_compare(rating_avg, RATING_AVG_TOP, 2) >= 0: return 'top' if float_compare(rating_avg, RATING_AVG_OK, 2) >= 0: return 'ok' if float_compare(rating_avg, RATING_AVG_MIN, 2) >= 0: return 'ko' return 'none' def _rating_assert_value(rating_value): assert RATING_NONE_VALUE <= rating_value <= RATING_HAPPY_VALUE def _rating_to_grade(rating_value): """ From a rating value give a text-based mean value. """ _rating_assert_value(rating_value) if rating_value >= RATING_LIMIT_SATISFIED: return 'great' if rating_value >= RATING_LIMIT_OK: return 'okay' return 'bad' def _rating_to_text(rating_value): """ From a rating value give a text-based mean value. """ _rating_assert_value(rating_value) if rating_value >= RATING_LIMIT_SATISFIED: return 'top' if rating_value >= RATING_LIMIT_OK: return 'ok' if rating_value >= RATING_LIMIT_MIN: return 'ko' return 'none' def _rating_to_threshold(rating_value): """ From a rating value, return the thresholds in form of 0-1-3-5 used notably for images. """ _rating_assert_value(rating_value) if rating_value >= RATING_LIMIT_SATISFIED: return RATING_HAPPY_VALUE if rating_value >= RATING_LIMIT_OK: return RATING_NEUTRAL_VALUE if rating_value >= RATING_LIMIT_MIN: return RATING_UNHAPPY_VALUE return RATING_NONE_VALUE