/************************************************************************ MeOS - Orienteering Software Copyright (C) 2009-2020 Melin Software HB This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . Melin Software HB - software@melin.nu - www.melin.nu Eksoppsvägen 16, SE-75646 UPPSALA, Sweden ************************************************************************/ #include "stdafx.h" #include #include "listeditor.h" #include "metalist.h" #include "gdioutput.h" #include "meosexception.h" #include "gdistructures.h" #include "meos_util.h" #include "localizer.h" #include "gdifonts.h" #include "oEvent.h" #include "tabbase.h" #include "CommDlg.h" #include "generalresult.h" ListEditor::ListEditor(oEvent *oe_) { oe = oe_; currentList = 0; currentIndex = -1; dirtyExt = false; dirtyInt = false; lastSaved = NotSaved; oe->loadGeneralResults(false, true); } ListEditor::~ListEditor() { setCurrentList(0); } void ListEditor::setCurrentList(MetaList *lst) { delete currentList; currentList = lst; } /* void ListEditor::load(MetaList *list) { currentList = list; currentIndex = -1; dirtyInt = true; dirtyExt = true; }*/ void ListEditor::load(const MetaListContainer &mlc, int index) { const MetaList &mc = mlc.getList(index); setCurrentList(new MetaList()); *currentList = mc; if (mlc.isInternal(index)) { currentIndex = -1; currentList->clearTag(); } else currentIndex = index; dirtyExt = true; dirtyInt = false; savedFileName.clear(); } void ListEditor::show(TabBase *dst, gdioutput &gdi) { gdi.clearPage(false); origin = dst; show(gdi); } void ListEditor::show(gdioutput &gdi) { gdi.setRestorePoint("BeginListEdit"); gdi.pushX(); gdi.setCX(gdi.getCX() + gdi.scaleLength(6)); int bx = gdi.getCX(); int by = gdi.getCY(); if (currentList) gdi.addString("", boldLarge, makeDash(L"Listredigerare - X#") + currentList->getListName()); else gdi.addString("", boldLarge, "Listredigerare"); gdi.setOnClearCb(editListCB); gdi.setData("ListEditorClz", this); gdi.dropLine(0.5); gdi.fillRight(); gdi.addButton("EditList", "Egenskaper", editListCB); gdi.setCX(gdi.getCX() + gdi.scaleLength(32)); gdi.addButton("OpenFile", "Öppna fil", editListCB); gdi.addButton("OpenInside", "Öppna från aktuell tävling", editListCB); if (savedFileName.empty()) gdi.addButton("SaveFile", "Spara som fil", editListCB); else { gdi.addButton("SaveFile", L"Spara fil", editListCB, L"#" + savedFileName); gdi.addButton("SaveFileCopy", "Spara som...", editListCB); } gdi.addButton("SaveInside", "Spara i aktuell tävling", editListCB); gdi.addButton("NewList", "Ny lista", editListCB); gdi.addButton("RemoveInside", "Radera", editListCB, "Radera listan från aktuell tävling"); gdi.setInputStatus("RemoveInside", currentIndex != -1); gdi.addButton("Close", "Stäng", editListCB); gdi.dropLine(2); int dx = gdi.getCX(); int dy = gdi.getCY(); RECT rc; int off = gdi.scaleLength(6); rc.left = bx - 2 * off; rc.right = dx + 2 * off; rc.top = by - off; rc.bottom = dy + off; gdi.addRectangle(rc, colorWindowBar); gdi.dropLine(); gdi.popX(); makeDirty(gdi, NoTouch, NoTouch); if (!currentList) { gdi.disableInput("EditList"); gdi.disableInput("SaveFile"); gdi.disableInput("SaveFileCopy", true); gdi.disableInput("SaveInside"); gdi.refresh(); return; } MetaList &list = *currentList; const vector< vector > &head = list.getHead(); gdi.fillDown(); gdi.addString("", 1, "Rubrik"); gdi.pushX(); gdi.fillRight(); const double buttonDrop = 2.2; int lineIx = 100; for (size_t k = 0; k < head.size(); k++) { showLine(gdi, head[k], lineIx++); gdi.popX(); gdi.dropLine(buttonDrop); } gdi.fillDown(); gdi.addButton("AddLine0", "Lägg till rad", editListCB); gdi.dropLine(0.5); gdi.addString("", 1, "Underrubrik"); gdi.pushX(); gdi.fillRight(); const vector< vector > &subHead = list.getSubHead(); lineIx = 200; for (size_t k = 0; k < subHead.size(); k++) { showLine(gdi, subHead[k], lineIx++); gdi.popX(); gdi.dropLine(buttonDrop); } gdi.fillDown(); gdi.addButton("AddLine1", "Lägg till rad", editListCB); gdi.dropLine(0.5); gdi.addString("", 1, "Huvudlista"); gdi.pushX(); gdi.fillRight(); const vector< vector > &mainList = list.getList(); lineIx = 300; for (size_t k = 0; k < mainList.size(); k++) { showLine(gdi, mainList[k], lineIx++); gdi.popX(); gdi.dropLine(buttonDrop); } gdi.fillDown(); gdi.addButton("AddLine2", "Lägg till rad", editListCB); gdi.dropLine(0.5); gdi.addString("", 1, "Underlista"); gdi.pushX(); gdi.fillRight(); const vector< vector > &subList = list.getSubList(); lineIx = 400; for (size_t k = 0; k < subList.size(); k++) { showLine(gdi, subList[k], lineIx++); gdi.popX(); gdi.dropLine(buttonDrop); } gdi.fillDown(); gdi.addButton("AddLine3", "Lägg till rad", editListCB); gdi.setRestorePoint("EditList"); gdi.dropLine(2); oListInfo li; oListParam par; par.pageBreak = false; par.splitAnalysis = true; par.setLegNumberCoded(-1); par.inputNumber = 0; gdi.fillDown(); try { currentList->interpret(oe, gdi, par, li); rc.left = gdi.getCX(); rc.right = gdi.getCX() + gdi.getWidth() - 20; rc.top = gdi.getCY(); rc.bottom = rc.top + 4; gdi.addRectangle(rc, colorDarkGreen, false, false); gdi.dropLine(); oe->generateList(gdi, false, li, true); } catch (meosException &ex) { gdi.addString("", 1, "Listan kan inte visas").setColor(colorRed); gdi.addString("", 0, ex.wwhat()); } catch (std::exception &ex) { gdi.addString("", 1, "Listan kan inte visas").setColor(colorRed); gdi.addString("", 0, ex.what()); } gdi.refresh(); } int editListCB(gdioutput *gdi, int type, void *data) { void *clz = gdi->getData("ListEditorClz"); ListEditor *le = (ListEditor *)clz; BaseInfo *bi = (BaseInfo *)data; if (le) return le->editList(*gdi, type, *bi); throw meosException("Unexpected error"); } void ListEditor::showLine(gdioutput &gdi, const vector &line, int ix) const { for (size_t k = 0; k < line.size(); k++) { addButton(gdi, line[k], gdi.getCX(), gdi.getCY(), ix, k); } gdi.addButton("AddPost" + itos(ix), "Lägg till ny", editListCB); } ButtonInfo &ListEditor::addButton(gdioutput &gdi, const MetaListPost &mlp, int x, int y, int lineIx, int ix) const { wstring cap; if (mlp.getType() == L"String") { cap = L"Text: X#" + mlp.getText(); } else { const wstring &text = mlp.getText(); if (text.length() > 0) { if (text[0] == '@') { vector part; split(text.substr(1), L";", part); unsplit(part, L"|", cap); } else cap = text + L"#" + lang.tl(mlp.getType()); } else { cap = mlp.getType(); } } ButtonInfo &bi = gdi.addButton(x, y, "EditPost" + itos(lineIx * 100 + ix), cap, editListCB); return bi; } static void getPosFromId(int id, int &groupIx, int &lineIx, int &ix) { lineIx = id / 100; ix = id % 100; groupIx = (lineIx / 100) - 1; lineIx = lineIx % 100; } int ListEditor::editList(gdioutput &gdi, int type, BaseInfo &data) { int lineIx, groupIx, ix; if (type == GUI_BUTTON) { ButtonInfo bi = dynamic_cast(data); ButtonInfo &biSrc = dynamic_cast(data); if (bi.id == "Color") { wstring c = oe->getPropertyString("Colors", L""); int res = gdi.selectColor(c, bi.getExtraInt()); if (res >= -1) { biSrc.setExtra(res); oe->setProperty("Colors", c); } /*CHOOSECOLOR cc; memset(&cc, 0, sizeof(cc)); cc.lStructSize = sizeof(cc); cc.hwndOwner = gdi.getHWND(); cc.rgbResult = COLORREF(bi.getExtra()); if (GDICOLOR((int)bi.getExtra()) != colorDefault) cc.Flags |= CC_RGBINIT; COLORREF staticColor[16]; memset(staticColor, 0, 16*sizeof(COLORREF)); const string &c = oe->getPropertyString("Colors", ""); const char *end = c.c_str() + c.length(); const char * pEnd = c.c_str(); int pix = 0; while(pEnd < end && pix < 16) { staticColor[pix++] = strtol(pEnd,(char **)&pEnd,16); } cc.lpCustColors = staticColor; if (ChooseColor(&cc)) { data.setExtra((int)cc.rgbResult); wstring co; for (ix = 0; ix < 16; ix++) { wchar_t bf[16]; swprintf_s(bf, L"%x ", staticColor[ix]); co += bf; } oe->setProperty("Colors", co); }*/ } if ( bi.id.substr(0, 8) == "EditPost" ) { int id = atoi(bi.id.substr(8).c_str()); getPosFromId(id, groupIx, lineIx, ix); MetaListPost &mlp = currentList->getMLP(groupIx, lineIx, ix); editListPost(gdi, mlp, id); } else if ( bi.id.substr(0, 7) == "AddPost" ) { checkUnsaved(gdi); gdi.restore("EditList", true); gdi.pushX(); lineIx = atoi(bi.id.substr(7).c_str()); groupIx = (lineIx / 100) - 1; int ixOutput = 0; MetaListPost &mlp = currentList->addNew(groupIx, lineIx % 100, ixOutput); int xp = bi.xp; int yp = bi.yp; ButtonInfo &nb = addButton(gdi, mlp, xp, yp, lineIx, ixOutput); //gdi.addButton(xp, yp, string("Foo"), string("FoooBar"), 0); int w, h; nb.getDimension(gdi, w, h); biSrc.moveButton(gdi, xp+w, yp); gdi.popX(); gdi.setRestorePoint("EditList"); makeDirty(gdi, MakeDirty, MakeDirty); gdi.sendCtrlMessage(nb.id); } else if ( bi.id.substr(0, 7) == "AddLine" ) { checkUnsaved(gdi); groupIx = atoi(bi.id.substr(7).c_str()); int ixOutput = 0; currentList->addNew(groupIx, -1, ixOutput); gdi.restore("BeginListEdit", false); makeDirty(gdi, MakeDirty, MakeDirty); show(gdi); } else if ( bi.id == "Remove" ) { DWORD id; gdi.getData("CurrentId", id); getPosFromId(id, groupIx, lineIx, ix); currentList->removeMLP(groupIx, lineIx, ix); gdi.restore("BeginListEdit", false); makeDirty(gdi, MakeDirty, MakeDirty); show(gdi); } else if (bi.id == "UseLeg") { gdi.setInputStatus("Leg", gdi.isChecked(bi.id)); } else if (bi.id == "Cancel") { gdi.restore("EditList"); gdi.enableInput("EditList"); } else if (bi.id == "CancelNew") { gdi.clearPage(false); currentList = 0; show(gdi); } else if (bi.id == "Apply" || bi.id == "MoveLeft" || bi.id == "MoveRight") { DWORD id; gdi.getData("CurrentId", id); getPosFromId(id, groupIx, lineIx, ix); if (bi.id == "MoveLeft") currentList->moveOnRow(groupIx, lineIx, ix, -1); else if (bi.id == "MoveRight") currentList->moveOnRow(groupIx, lineIx, ix, 1); MetaListPost &mlp = currentList->getMLP(groupIx, lineIx, ix); ListBoxInfo lbi; bool force = false; gdi.getSelectedItem("Type", lbi); EPostType ptype = EPostType(lbi.data); wstring str = gdi.getText("Text"); if (ptype != lString) { if (!str.empty() && str.find_first_of('X') == string::npos && str[0]!='@') { throw meosException("Texten ska innehålla tecknet X, som byts ut mot tävlingsspecifik data"); } } wstring t1 = mlp.getType(); EPostType newType = EPostType(lbi.data); mlp.setType(newType); if (t1 != mlp.getType()) force = true; mlp.setText(str); gdi.getSelectedItem("AlignType", lbi); mlp.align(EPostType(lbi.data), gdi.isChecked("BlockAlign")); mlp.alignText(gdi.getText("AlignText")); mlp.mergePrevious(gdi.isChecked("MergeText")); gdi.getSelectedItem("TextAdjust", lbi); mlp.setTextAdjust(lbi.data); mlp.setColor(GDICOLOR(gdi.getExtraInt("Color"))); if (gdi.isChecked("UseLeg")) { int leg = gdi.getTextNo("Leg"); if (newType == lResultModuleNumber || newType == lResultModuleTime || newType == lResultModuleNumberTeam || newType == lResultModuleTimeTeam) { if (leg < 0 || leg > 1000) throw meosException("X är inget giltigt index#" + itos(leg)); mlp.setLeg(leg); } else { if (leg < 1 || leg > 1000) throw meosException("X är inget giltigt sträcknummer#" + itos(leg)); mlp.setLeg(leg - 1); } } else mlp.setLeg(-1); if (gdi.hasWidget("UseResultModule") && gdi.isChecked("UseResultModule")) mlp.setResultModule(currentList->getResultModule()); else mlp.setResultModule(""); mlp.setBlock(gdi.getTextNo("BlockSize")); mlp.indent(gdi.getTextNo("MinIndeent")); gdi.getSelectedItem("Fonts", lbi); mlp.setFont(gdiFonts(lbi.data)); makeDirty(gdi, MakeDirty, MakeDirty); if (!gdi.hasData("NoRedraw") || force) { gdi.restore("BeginListEdit", false); show(gdi); } } else if (bi.id == "ApplyListProp") { wstring name = gdi.getText("Name"); if (name.empty()) throw meosException("Namnet kan inte vara tomt"); MetaList &list = *currentList; list.setListName(name); ListBoxInfo lbi; if (gdi.getSelectedItem("SortOrder", lbi)) list.setSortOrder(SortOrder(lbi.data)); if (gdi.getSelectedItem("BaseType", lbi)) list.setListType(oListInfo::EBaseType(lbi.data)); if (gdi.getSelectedItem("ResultType", lbi)) list.setResultModule(*oe, lbi.data); if (gdi.getSelectedItem("SubType", lbi)) list.setSubListType(oListInfo::EBaseType(lbi.data)); vector< pair > filtersIn; vector< bool > filtersOut; list.getFilters(filtersIn); for (size_t k = 0; k < filtersIn.size(); k++) filtersOut.push_back(gdi.isChecked("filter" + itos(k))); list.setFilters(filtersOut); vector< pair > subFiltersIn; vector< bool > subFiltersOut; list.getSubFilters(subFiltersIn); for (size_t k = 0; k < subFiltersIn.size(); k++) subFiltersOut.push_back(gdi.isChecked("subfilter" + itos(k))); list.setSubFilters(subFiltersOut); for (int k = 0; k < 4; k++) { list.setFontFace(k, gdi.getText("Font" + itos(k)), gdi.getTextNo("FontFactor" + itos(k))); int f = gdi.getTextNo("ExtraSpace" + itos(k)); list.setExtraSpace(k, f); } list.setSupportFromTo(gdi.isChecked("SupportFrom"), gdi.isChecked("SupportTo")); list.setSupportLegSelection(gdi.isChecked("SupportLegSelection")); makeDirty(gdi, MakeDirty, MakeDirty); if (!gdi.hasData("NoRedraw")) { gdi.clearPage(false); show(gdi); } } else if (bi.id == "EditList") { editListProp(gdi, false); } else if (bi.id == "NewList") { if (!checkSave(gdi)) return 0; gdi.clearPage(false); gdi.setData("ListEditorClz", this); gdi.addString("", boldLarge, "Ny lista"); setCurrentList(new MetaList()); currentIndex = -1; lastSaved = NotSaved; makeDirty(gdi, ClearDirty, ClearDirty); editListProp(gdi, true); } else if (bi.id == "MakeNewList") { /* currentList->setListName(lang.tl("Ny lista")); currentIndex = -1; lastSaved = NotSaved; makeDirty(gdi, ClearDirty, ClearDirty); gdi.clearPage(false); show(gdi);*/ } else if (bi.id == "SaveFile" || bi.id == "SaveFileCopy") { if (!currentList) return 0; bool copy = bi.id == "SaveFileCopy"; wstring fileName = copy ? L"" : savedFileName; if (fileName.empty()) { int ix = 0; vector< pair > ext; ext.push_back(make_pair(L"xml-data", L"*.xml")); fileName = gdi.browseForSave(ext, L"xml", ix); if (fileName.empty()) return 0; } currentList->save(fileName, oe); lastSaved = SavedFile; makeDirty(gdi, NoTouch, ClearDirty); savedFileName = fileName; return 1; } else if (bi.id == "OpenFile") { if (!checkSave(gdi)) return 0; vector< pair > ext; ext.push_back(make_pair(L"xml-data", L"*.xml")); wstring fileName = gdi.browseForOpen(ext, L"xml"); if (fileName.empty()) return 0; MetaList *tmp = new MetaList(); try { tmp->setListName(lang.tl(L"Ny lista")); tmp->load(fileName); } catch(...) { delete tmp; throw; } setCurrentList(tmp); currentIndex = -1; gdi.clearPage(false); lastSaved = SavedFile; savedFileName = fileName; oe->loadGeneralResults(true, true); makeDirty(gdi, ClearDirty, ClearDirty); show(gdi); } else if (bi.id == "OpenInside") { if (!checkSave(gdi)) return 0; savedFileName.clear(); gdi.clearPage(true); gdi.setOnClearCb(editListCB); gdi.setData("ListEditorClz", this); gdi.pushX(); vector< pair > lists; oe->getListContainer().getLists(lists, true, false, false); reverse(lists.begin(), lists.end()); gdi.fillRight(); gdi.addSelection("OpenList", 250, 400, editListCB, L"Välj lista:"); gdi.addItem("OpenList", lists); gdi.selectFirstItem("OpenList"); gdi.dropLine(); gdi.addButton("DoOpen", "Öppna", editListCB); gdi.addButton("DoOpenCopy", "Open a Copy", editListCB); enableOpen(gdi); gdi.addButton("CancelReload", "Avbryt", editListCB).setCancel(); gdi.dropLine(4); gdi.popX(); } else if (bi.id == "DoOpen" || bi.id == "DoOpenCopy" ) { ListBoxInfo lbi; if (gdi.getSelectedItem("OpenList", lbi)) { load(oe->getListContainer(), lbi.data); } if (bi.id == "DoOpenCopy") { currentIndex = -1; currentList->clearTag(); lastSaved = NotSaved; makeDirty(gdi, MakeDirty, MakeDirty); } else { lastSaved = SavedInside; makeDirty(gdi, ClearDirty, ClearDirty); } gdi.clearPage(false); show(gdi); } else if (bi.id == "CancelReload") { gdi.clearPage(false); show(gdi); } else if (bi.id == "SaveInside") { if (currentList == 0) return 0; savedFileName.clear(); oe->synchronize(false); if (currentIndex != -1) { oe->getListContainer().saveList(currentIndex, *currentList); } else { oe->getListContainer().addExternal(*currentList); currentIndex = oe->getListContainer().getNumLists() - 1; oe->getListContainer().saveList(currentIndex, *currentList); } oe->synchronize(true); lastSaved = SavedInside; makeDirty(gdi, ClearDirty, ClearDirty); } else if (bi.id == "RemoveInside") { if (currentIndex != -1) { oe->getListContainer().removeList(currentIndex); currentIndex = -1; savedFileName.clear(); if (lastSaved == SavedInside) lastSaved = NotSaved; gdi.alert("Listan togs bort från tävlingen."); makeDirty(gdi, MakeDirty, NoTouch); gdi.setInputStatus("RemoveInside", false); } } else if (bi.id == "Close") { if (!checkSave(gdi)) return 0; setCurrentList(0); makeDirty(gdi, ClearDirty, ClearDirty); currentIndex = -1; savedFileName.clear(); if (origin) { auto oc = origin; origin = nullptr; oc->loadPage(gdi); } return 0; } /*else if (bi.id == "BrowseFont") { InitCommonControls(); CHOOSEFONT cf; memset(&cf, 0, sizeof(cf)); cf.lStructSize = sizeof(cf); cf.hwndOwner = gdi.getHWND(); ChooseFont(&cf); EnumFontFamilies( }*/ } else if (type == GUI_LISTBOX) { ListBoxInfo &lbi = dynamic_cast(data); if (lbi.id == "AlignType") { gdi.setInputStatus("AlignText", lbi.data == lString); if (lbi.data == lString) { int ix = lbi.text.find_first_of(L":"); if (ix != lbi.text.npos) gdi.setText("AlignText", lbi.text.substr(ix+1)); } else gdi.setText("AlignText", L""); } else if (lbi.id == "Type") { EPostType type = EPostType(lbi.data); gdi.setTextTranslate("TUseLeg", getIndexDescription(type), true); if (type == lResultModuleNumber || type == lResultModuleTime || type == lResultModuleNumberTeam || type == lResultModuleTimeTeam) { gdi.check("UseLeg", true); gdi.disableInput("UseLeg"); if (gdi.hasWidget("UseResultModule")) { gdi.check("UseResultModule", true); gdi.disableInput("UseResultModule"); } gdi.enableInput("Leg"); if (gdi.getText("Leg").empty()) gdi.setText("Leg", L"0"); } else { gdi.enableInput("UseLeg"); if (gdi.getTextNo("Leg") == 0) { gdi.setText("Leg", L""); gdi.enableInput("UseLeg"); gdi.enableInput("UseResultModule", true); gdi.check("UseLeg", false); gdi.disableInput("Leg"); } } } else if (lbi.id == "SubType") { oListInfo::EBaseType subType = oListInfo::EBaseType(lbi.data); vector< pair > subfilters; currentList->getSubFilters(subfilters); for (size_t k = 0; k < subfilters.size(); k++) { gdi.setInputStatus("subfilter" + itos(k), subType != oListInfo::EBaseTypeNone); } } else if (lbi.id == "ResultType") { vector< pair > types; int currentType = 0; currentList->getSortOrder(lbi.data != 0, types, currentType); if (lbi.data == 0) { ListBoxInfo mlbi; gdi.getSelectedItem("SortOrder", mlbi); currentType = mlbi.data; } gdi.addItem("SortOrder", types); gdi.selectItemByData("SortOrder", currentType); } else if (lbi.id == "OpenList") { enableOpen(gdi); } } else if (type==GUI_CLEAR) { return checkSave(gdi); } return 0; } void ListEditor::checkUnsaved(gdioutput &gdi) { if (gdi.hasData("IsEditing")) { if (gdi.isInputChanged("")) { gdi.setData("NoRedraw", 1); gdi.sendCtrlMessage("Apply"); } } if (gdi.hasData("IsEditingList")) { if (gdi.isInputChanged("")) { gdi.setData("NoRedraw", 1); gdi.sendCtrlMessage("ApplyListProp"); } } } void ListEditor::editListPost(gdioutput &gdi, const MetaListPost &mlp, int id) { checkUnsaved(gdi); gdi.restore("EditList", false); gdi.dropLine(); gdi.enableInput("EditList"); int groupIx, lineIx, ix; getPosFromId(id, groupIx, lineIx, ix); const bool hasResultModule = currentList && !currentList->getResultModule().empty(); int x1 = gdi.getCX(); int y1 = gdi.getCY(); int margin = gdi.scaleLength(10); gdi.setCX(x1+margin); gdi.dropLine(); gdi.pushX(); gdi.fillRight(); gdi.addString("", boldLarge, "Listpost").setColor(colorDarkGrey); gdi.setCX(gdi.getCX() + gdi.scaleLength(20)); gdi.addButton("MoveLeft", "<< Flytta vänster", editListCB); gdi.addButton("MoveRight", "Flytta höger >>", editListCB); gdi.dropLine(3); gdi.popX(); vector< pair > types; int currentType; mlp.getTypes(types, currentType); EPostType storedType = EPostType(currentType); if (!hasResultModule) { for (size_t k = 0; k < types.size(); k++) { if ( (storedType != lResultModuleNumber && types[k].second == lResultModuleNumber) || (storedType != lResultModuleTime && types[k].second == lResultModuleTime) || (storedType != lResultModuleNumberTeam && types[k].second == lResultModuleNumberTeam) || (storedType != lResultModuleTimeTeam && types[k].second == lResultModuleTimeTeam)) { swap(types[k], types.back()); types.pop_back(); k--; } } } sort(types.begin(), types.end()); gdi.pushX(); gdi.fillRight(); int boxY = gdi.getCY(); gdi.addSelection("Type", 290, 500, editListCB, L"Typ:"); gdi.addItem("Type", types); gdi.selectItemByData("Type", currentType); gdi.addInput("Text", mlp.getText(), 16, 0, L"Egen text:", L"Använd symbolen X där MeOS ska fylla i typens data."); int boxX = gdi.getCX(); gdi.popX(); gdi.fillRight(); gdi.dropLine(3); currentList->getAlignTypes(mlp, types, currentType); sort(types.begin(), types.end()); gdi.addSelection("AlignType", 290, 500, editListCB, L"Justera mot:"); gdi.addItem("AlignType", types); gdi.selectItemByData("AlignType", currentType); gdi.addInput("AlignText", mlp.getAlignText(), 16, 0, L"Text:"); if (currentType != lString) gdi.disableInput("AlignText"); gdi.popX(); gdi.dropLine(3); gdi.fillRight(); gdi.addCheckbox("BlockAlign", "Justera blockvis:", 0, mlp.getAlignBlock()); gdi.dropLine(-0.2); gdi.addInput("BlockSize", itow(mlp.getBlockWidth()), 5, 0, L"", L"Blockbredd"); gdi.dropLine(2.1); gdi.popX(); gdi.fillRight(); if (hasResultModule) { gdi.addCheckbox("UseResultModule", "Data from result module (X)#" + currentList->getResultModule(), 0, !mlp.getResultModule().empty()); gdi.dropLine(1.5); gdi.popX(); } int leg = mlp.getLeg(); gdi.addCheckbox("UseLeg", getIndexDescription(storedType), editListCB, leg != -1); gdi.dropLine(-0.2); gdi.setCX(gdi.getCX() + gdi.getLineHeight() * 5); if (storedType == lResultModuleNumber || storedType == lResultModuleTime || storedType == lResultModuleTimeTeam || storedType == lResultModuleNumberTeam) gdi.addInput("Leg", leg>=0 ? itow(leg) : L"0", 4); else gdi.addInput("Leg", leg>=0 ? itow(leg + 1) : L"", 4); if (storedType == lResultModuleNumber || storedType == lResultModuleTime || storedType == lResultModuleTimeTeam || storedType == lResultModuleNumberTeam) { gdi.check("UseLeg", true); gdi.disableInput("UseLeg"); if (gdi.hasWidget("UseResultModule")) { gdi.check("UseResultModule", true); gdi.disableInput("UseResultModule"); } } gdi.dropLine(2); if (ix>0) { gdi.popX(); gdi.addCheckbox("MergeText", "Slå ihop text med föregående", 0, mlp.isMergePrevious()); gdi.dropLine(2); } int maxY = gdi.getCY(); gdi.popX(); gdi.fillDown(); gdi.setCX(boxX + gdi.scaleLength(24)); gdi.setCY(boxY); gdi.pushX(); gdi.addString("", 1, "Formateringsregler"); gdi.dropLine(0.5); gdi.fillRight(); gdi.addInput("MinIndeent", itow(mlp.getMinimalIndent()), 7, 0, L"Minsta intabbning:"); vector< pair > fonts; int currentFont; mlp.getFonts(fonts, currentFont); gdi.addSelection("Fonts", 150, 500, 0, L"Format:"); gdi.addItem("Fonts", fonts); gdi.selectItemByData("Fonts", currentFont); int maxX = gdi.getCX(); gdi.popX(); gdi.dropLine(3); gdi.addSelection("TextAdjust", 150, 100, 0, L"Textjustering:"); gdi.addItem("TextAdjust", lang.tl("Vänster"), 0); gdi.addItem("TextAdjust", lang.tl("Höger"), textRight); gdi.addItem("TextAdjust", lang.tl("Centrera"), textCenter); gdi.selectItemByData("TextAdjust", mlp.getTextAdjustNum()); //gdi.popX(); //gdi.dropLine(2); gdi.dropLine(); gdi.addButton("Color", "Färg...", editListCB).setExtra(mlp.getColorValue()); maxX = max(maxX, gdi.getCX()); gdi.popX(); gdi.dropLine(3); gdi.setData("CurrentId", id); gdi.addButton("Remove", "Radera", editListCB, "Ta bort listposten"); gdi.addButton("Cancel", "Avbryt", editListCB).setCancel(); gdi.updatePos(gdi.getCX(), gdi.getCY(), gdi.scaleLength(20), 0); gdi.addButton("Apply", "OK", editListCB).setDefault(); gdi.dropLine(3); maxY = max(maxY, gdi.getCY()); maxX = max(gdi.getCX(), maxX); gdi.fillDown(); gdi.popX(); gdi.setData("IsEditing", 1); RECT rc; rc.top = y1; rc.left = x1; rc.right = maxX + gdi.scaleLength(6); rc.bottom = maxY + gdi.scaleLength(6); gdi.addRectangle(rc, colorLightBlue, true); gdi.scrollToBottom(); gdi.refresh(); } const wchar_t *ListEditor::getIndexDescription(EPostType type) { if (type == lResultModuleTime || type == lResultModuleTimeTeam) return L"Index in X[index]#OutputTimes"; else if (type == lResultModuleNumber || type == lResultModuleNumberTeam) return L"Index in X[index]#OutputNumbers"; else return L"Applicera för specifik sträcka:"; } void ListEditor::editListProp(gdioutput &gdi, bool newList) { checkUnsaved(gdi); if (!currentList) return; MetaList &list = *currentList; if (!newList) { gdi.restore("EditList", false); gdi.disableInput("EditList"); } gdi.dropLine(0.8); int x1 = gdi.getCX(); int y1 = gdi.getCY(); int margin = gdi.scaleLength(10); gdi.setCX(x1+margin); if (!newList) { gdi.dropLine(); gdi.fillDown(); gdi.addString("", boldLarge, "Listegenskaper").setColor(colorDarkGrey); gdi.dropLine(); } gdi.fillRight(); gdi.pushX(); gdi.addInput("Name", list.getListName(), 20, 0, L"Listnamn:"); if (newList) { gdi.dropLine(3.5); gdi.popX(); } vector< pair > types; int currentType = 0; int maxX = gdi.getCX(); list.getBaseType(types, currentType); gdi.addSelection("BaseType", 150, 400, 0, L"Listtyp:"); gdi.addItem("BaseType", types); gdi.selectItemByData("BaseType", currentType); gdi.autoGrow("BaseType"); list.getResultModule(*oe, types, currentType); gdi.addSelection("ResultType", 150, 400, editListCB, L"Resultatuträkning:"); gdi.addItem("ResultType", types); gdi.autoGrow("ResultType"); gdi.selectItemByData("ResultType", currentType); list.getSortOrder(false, types, currentType); gdi.addSelection("SortOrder", 170, 400, 0, L"Global sorteringsordning:"); gdi.addItem("SortOrder", types); gdi.autoGrow("SortOrder"); gdi.selectItemByData("SortOrder", currentType); list.getSubType(types, currentType); gdi.addSelection("SubType", 150, 400, editListCB, L"Sekundär typ:"); gdi.addItem("SubType", types); gdi.selectItemByData("SubType", currentType); oListInfo::EBaseType subType = oListInfo::EBaseType(currentType); maxX = max(maxX, gdi.getCX()); gdi.popX(); gdi.dropLine(3); gdi.fillRight(); gdi.addCheckbox("SupportFrom", "Support time from control", 0, list.supportFrom()); gdi.addCheckbox("SupportTo", "Support time to control", 0, list.supportTo()); gdi.addCheckbox("SupportLegSelection", "Support intermediate legs", 0, list.supportLegSelection()); gdi.dropLine(2); gdi.popX(); gdi.fillDown(); gdi.addString("", 1, "Filter"); gdi.dropLine(0.5); vector< pair > filters; list.getFilters(filters); gdi.fillRight(); int xp = gdi.getCX(); int yp = gdi.getCY(); //const int w = gdi.scaleLength(130); for (size_t k = 0; k < filters.size(); k++) { gdi.addCheckbox(xp, yp, "filter" + itos(k), filters[k].first, 0, filters[k].second); xp = gdi.getCX(); maxX = max(maxX, xp); if (k % 10 == 9) { xp = x1 + margin; gdi.setCX(xp); yp += int(1.3 * gdi.getLineHeight()); gdi.dropLine(1.3); } } gdi.popX(); gdi.dropLine(2); gdi.fillDown(); gdi.addString("", 1, "Underfilter"); gdi.dropLine(0.5); vector< pair > subfilters; list.getSubFilters(subfilters); gdi.fillRight(); xp = gdi.getCX(); yp = gdi.getCY(); for (size_t k = 0; k < subfilters.size(); k++) { gdi.addCheckbox(xp, yp, "subfilter" + itos(k), subfilters[k].first, 0, subfilters[k].second); if (subType == oListInfo::EBaseTypeNone) gdi.disableInput(("subfilter" + itos(k)).c_str()); //xp += w; xp = gdi.getCX(); maxX = max(maxX, xp); if (k % 10 == 9) { xp = x1 + margin; gdi.setCX(xp); yp += int(1.3 * gdi.getLineHeight()); } } gdi.popX(); gdi.dropLine(2); gdi.fillDown(); gdi.addString("", 1, "Typsnitt"); gdi.dropLine(0.5); gdi.fillRight(); const wchar_t *expl[4] = {L"Rubrik", L"Underrubrik", L"Lista", L"Underlista"}; vector< pair > fonts; gdi.getEnumeratedFonts(fonts); sort(fonts.begin(), fonts.end()); for (int k = 0; k < 4; k++) { string id("Font" + itos(k)); gdi.addCombo(id, 200, 300, 0, expl[k]); gdi.addItem(id, fonts); gdi.setText(id, list.getFontFace(k)); gdi.setCX(gdi.getCX()+20); int f = list.getFontFaceFactor(k); wstring ff = f == 0 ? L"100 %" : itow(f) + L" %"; gdi.addInput("FontFactor" + itos(k), ff, 4, 0, L"Skalfaktor", L"Relativ skalfaktor för typsnittets storlek i procent"); f = list.getExtraSpace(k); gdi.addInput("ExtraSpace" + itos(k), itow(f), 4, 0, L"Avstånd", L"Extra avstånd ovanför textblock"); if (k == 1) { gdi.dropLine(3); gdi.popX(); } } if (!newList) { gdi.dropLine(0.8); gdi.setCX(gdi.getCX()+20); gdi.addButton("ApplyListProp", "OK", editListCB); gdi.addButton("Cancel", "Avbryt", editListCB); } else { gdi.setCX(x1); gdi.setCY(gdi.getHeight()); gdi.dropLine(); gdi.addButton("ApplyListProp", "Skapa", editListCB); gdi.addButton("CancelNew", "Avbryt", editListCB); } gdi.dropLine(3); int maxY = gdi.getCY(); gdi.fillDown(); gdi.popX(); gdi.setData("IsEditingList", 1); RECT rc; rc.top = y1; rc.left = x1; rc.right = maxX + gdi.scaleLength(6); rc.bottom = maxY; if (!newList) { gdi.addRectangle(rc, colorLightBlue, true); } gdi.scrollToBottom(); gdi.refresh(); gdi.setInputFocus("Name"); } void ListEditor::makeDirty(gdioutput &gdi, DirtyFlag inside, DirtyFlag outside) { if (inside == MakeDirty) dirtyInt = true; else if (inside == ClearDirty) dirtyInt = false; if (outside == MakeDirty) dirtyExt = true; else if (outside == ClearDirty) dirtyExt = false; if (gdi.hasWidget("SaveInside")) { gdi.setInputStatus("SaveInside", dirtyInt || lastSaved != SavedInside); } if (gdi.hasWidget("SaveFile")) { gdi.setInputStatus("SaveFile", dirtyExt || lastSaved != SavedFile); } } bool ListEditor::checkSave(gdioutput &gdi) { if (dirtyInt || dirtyExt) { gdioutput::AskAnswer answer = gdi.askCancel(L"Vill du spara ändringar?"); if (answer == gdioutput::AnswerCancel) return false; if (answer == gdioutput::AnswerYes) { if (currentIndex >= 0) gdi.sendCtrlMessage("SaveInside"); else if (gdi.sendCtrlMessage("SaveFile") == 0) return false; } makeDirty(gdi, ClearDirty, ClearDirty); } return true; } void ListEditor::enableOpen(gdioutput &gdi) { ListBoxInfo lbi; bool enabled = true; if (gdi.getSelectedItem("OpenList", lbi)) { if (oe->getListContainer().isInternal(lbi.data)) enabled = false; } gdi.setInputStatus("DoOpen", enabled); }