Source code for temporal.gui_support
"""
GUI support functions
(C) 2008-2011 by the GRASS Development Team
This program is free software under the GNU General Public
License (>=v2). Read the file COPYING that comes with GRASS
for details.
:authors: Soeren Gebbert
"""
from .core import get_available_temporal_mapsets, init_dbif
from .factory import dataset_factory
import grass.script as gscript
###############################################################################
[docs]def tlist_grouped(type, group_type=False, dbif=None):
    """List of temporal elements grouped by mapsets.
    Returns a dictionary where the keys are mapset
    names and the values are lists of space time datasets in that
    mapset. Example:
    .. code-block:: python
        >>> import grass.temporalas tgis
        >>> tgis.tlist_grouped('strds')['PERMANENT']
        ['precipitation', 'temperature']
    :param type: element type (strds, str3ds, stvds)
    :param group_type: TBD
    :return: directory of mapsets/elements
    """
    result = {}
    dbif, connected = init_dbif(dbif)
    mapset = None
    if type == 'stds':
        types = ['strds', 'str3ds', 'stvds']
    else:
        types = [type]
    for type in types:
        try:
            tlist_result = tlist(type=type, dbif=dbif)
        except gscript.ScriptError as e:
            warning(e)
            continue
        for line in tlist_result:
            try:
                name, mapset = line.split('@')
            except ValueError:
                warning(_("Invalid element '%s'") % line)
                continue
            if mapset not in result:
                if group_type:
                    result[mapset] = {}
                else:
                    result[mapset] = []
            if group_type:
                if type in result[mapset]:
                    result[mapset][type].append(name)
                else:
                    result[mapset][type] = [name, ]
            else:
                result[mapset].append(name)
    if connected is True:
        dbif.close()
    return result 
###############################################################################
[docs]def tlist(type, dbif=None):
    """Return a list of space time datasets of absolute and relative time
    :param type: element type (strds, str3ds, stvds)
    :return: a list of space time dataset ids
    """
    id = None
    sp = dataset_factory(type, id)
    dbif, connected = init_dbif(dbif)
    mapsets = get_available_temporal_mapsets()
    output = []
    temporal_type = ["absolute", 'relative']
    for type in temporal_type:
        # For each available mapset
        for mapset in mapsets.keys():
            # Table name
            if type == "absolute":
                table = sp.get_type() + "_view_abs_time"
            else:
                table = sp.get_type() + "_view_rel_time"
            # Create the sql selection statement
            sql = "SELECT id FROM " + table
            sql += " WHERE mapset = '%s'" % (mapset)
            sql += " ORDER BY id"
            dbif.execute(sql,  mapset=mapset)
            rows = dbif.fetchall(mapset=mapset)
            # Append the ids of the space time datasets
            for row in rows:
                for col in row:
                    output.append(str(col))
    if connected is True:
        dbif.close()
    return output