File indexing completed on 2024-09-08 11:04:08

0001 /***************************************************************************
0002  *   Copyright (C) 2003-2006 David Saxton <david@bluehaze.org>             *
0003  *                                                                         *
0004  *   This program is free software; you can redistribute it and/or modify  *
0005  *   it under the terms of the GNU General Public License as published by  *
0006  *   the Free Software Foundation; either version 2 of the License, or     *
0007  *   (at your option) any later version.                                   *
0008  ***************************************************************************/
0009 
0010 #ifndef ITEMLIBRARY_H
0011 #define ITEMLIBRARY_H
0012 
0013 #include <KLocalizedString>
0014 
0015 #include <QColor>
0016 #include <QMap>
0017 #include <QObject>
0018 
0019 class Component;
0020 class Document;
0021 class Item;
0022 class ItemDocument;
0023 class ItemLibrary;
0024 class LibraryItem;
0025 inline ItemLibrary *itemLibrary();
0026 
0027 typedef QMap<QString, QString> QStringMap;
0028 typedef QMap<QString, QStringMap> QStringMapMap;
0029 typedef QMap<QString, QImage> ImageMap;
0030 typedef QList<LibraryItem *> LibraryItemList;
0031 
0032 /**
0033 While the program is running, only one instance of this class is created.
0034 You can get it by calling itemLibrary()
0035 @short Holds the list of CNItems
0036 @author David Saxton
0037 */
0038 class ItemLibrary : public QObject
0039 {
0040     Q_OBJECT
0041 public:
0042     ~ItemLibrary() override;
0043     /**
0044      * Append the given item into the library
0045      */
0046     void addLibraryItem(LibraryItem *item);
0047     /**
0048      * Returns a list of items in the library
0049      */
0050     LibraryItemList *items()
0051     {
0052         return &m_items;
0053     }
0054     /**
0055      * @return the LibraryItem for the item with the given type (id) const.
0056      */
0057     LibraryItem *libraryItem(QString type) const;
0058     /**
0059      * Creates a new item with the given id, and returns a pointer to it
0060      */
0061     Item *createItem(const QString &id, ItemDocument *itemDocument, bool newItem, const char *newId = nullptr, bool finishCreation = true);
0062     /**
0063      * Returns an image of the given component. As QPixmap::toImage is
0064      * a slow function, this will cache the result and return that for large
0065      * images.
0066      * @param component A pointer to the Component.
0067      * @param maxSize The maximum size (in pixels) before the image is
0068      * cached.
0069      */
0070     QImage componentImage(Component *component, const uint maxSize = 36000);
0071     /**
0072      * Does similar to that above, but will not be able to return a description
0073      * if there is none saved on file (instead of the above, which falls back to
0074      * calling item->description()).
0075      * @param type the id of the item.
0076      * @param language the language code, e.g. "es".
0077      */
0078     QString description(QString type, const QString &language) const;
0079     /**
0080      * @return if we have a description for the item in language.
0081      */
0082     bool haveDescription(QString type, const QString &language) const;
0083     /**
0084      * Gives the type item the description.
0085      * @param type the type of item this description is for.
0086      * @param language the language code, e.g. "es".
0087      * @return whether the descriptions file could be saved.
0088      */
0089     bool setDescription(QString type, const QString &description, const QString &language);
0090     /**
0091      * @return the directory containing the item descriptions. By default,
0092      * this is something like "/usr/share/apps/ktechlab/contexthelp/". But
0093      * can be changed by calling setDescriptionsDirectory.
0094      */
0095     QString itemDescriptionsDirectory() const;
0096     /**
0097      * Stores the item descriptions directory in the users config.
0098      */
0099     void setItemDescriptionsDirectory(QString dir);
0100     /**
0101      * @return the item description file for the given language.
0102      */
0103     QString itemDescriptionsFile(const QString &language) const;
0104     /**
0105      * @return the string used for an empty item description - something like
0106      * "The help for English does not yet exist..". This is created by inserting
0107      * the current language name into m_emptyItemDescription;
0108      */
0109     QString emptyItemDescription(const QString &language) const;
0110     /**
0111      * @return the list of language-codes that have item descriptions.
0112      */
0113     QStringList descriptionLanguages() const
0114     {
0115         return m_itemDescriptions.keys();
0116     }
0117 
0118 protected:
0119     /**
0120      * Saves the item descriptions to the file specified in the config.
0121      * @return whether successful (e.g. if the file could be opened for
0122      * writing).
0123      */
0124     bool saveDescriptions(const QString &language);
0125     void loadItemDescriptions();
0126     void addComponents();
0127     void addFlowParts();
0128     void addMechanics();
0129     void addDrawParts();
0130 
0131     ItemLibrary();
0132 
0133     LibraryItemList m_items;
0134     ImageMap m_imageMap;
0135     QStringMapMap m_itemDescriptions;               // (Language, type) <--> description
0136     static KLocalizedString m_emptyItemDescription; // Description template for when a description does not yet exist
0137 
0138     friend ItemLibrary *itemLibrary();
0139 };
0140 
0141 inline ItemLibrary *itemLibrary()
0142 {
0143     // are we really sure we aren't calling new over and over again?
0144     static ItemLibrary *_itemLibrary = new ItemLibrary();
0145     return _itemLibrary;
0146 }
0147 
0148 #endif