diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2021-11-02 18:19:03 +0100 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2022-07-08 09:58:49 +0200 |
commit | 14a0da5cb7a794008227cc5c35beadc5f8060b93 (patch) | |
tree | 37336a463b9a68d957fa30ce721ca9452826b7b7 /ishtar_common/models_common.py | |
parent | c153a9d9891c724e711a57cbc49ac0723b37ac8a (diff) | |
download | Ishtar-14a0da5cb7a794008227cc5c35beadc5f8060b93.tar.bz2 Ishtar-14a0da5cb7a794008227cc5c35beadc5f8060b93.zip |
JSON types: multi valued choices
Diffstat (limited to 'ishtar_common/models_common.py')
-rw-r--r-- | ishtar_common/models_common.py | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/ishtar_common/models_common.py b/ishtar_common/models_common.py index e67b78d67..b1c291bee 100644 --- a/ishtar_common/models_common.py +++ b/ishtar_common/models_common.py @@ -1077,12 +1077,22 @@ class JsonData(models.Model, CachedGen): q = cls.objects.filter(data__has_key=key[len("data__") :]).values_list( "data", flat=True ) + multi = False for value in q.all(): for k in splitted_key: value = value[k] - choices.add(value) - choices = [("", "")] + [(v, v) for v in sorted(list(choices))] - cache.set(cache_key, choices, settings.CACHE_SMALLTIMEOUT) + if isinstance(value, list): + multi = True + for v in value: + if v: + choices.add(v) + else: + choices.add(value) + c = [] + if not multi: + c = [("", "")] + c += [(v, v) for v in sorted(list(choices))] + cache.set(cache_key, c, settings.CACHE_SMALLTIMEOUT) return choices |