Meeskond "Nämm-nämm": Difference between revisions
Line 116: | Line 116: | ||
* Joosep Ilves - 1p | * Joosep Ilves - 1p | ||
* Kaspar Kallasmaa - | * Kaspar Kallasmaa - 100p | ||
* Siim Aaver - 58p | * Siim Aaver - 58p | ||
Revision as of 18:02, 5 June 2011
Idee
Meie poolne teenus:
Meie poolt pakutud teenus lubab kohvikupidajatel oma kohvikuid ja seal pakutavaid toite süsteemi registreerida. Süsteemis on võimalik kohvikuid ja nende kaupa ilma sisse logimata kommenteerida ja võibolla ehk isegi hinnata.
Rakendus:
Tuleb üks asp.net veebileht, kus kohvikupidajatel on võimalus sisselogides oma menüüd üles panna/neid muuta/kustutada jne. Kui (tava)kasutaja tuleb lehele, on tal võimalus sisestada oma aadress, mille peale kuvatakse talle lähima kohviku asukoht (kaardi pealt näeb ka teiste kohvikute aadresse). Loomulikult on võimalik vaadata kõigi kohvikute menüüsid ning otsida menüüde seast meelepärast toitu. Mingit otsest sisselogimist pealehelt ei tule, selle jaoks teeb eraldi lehe.
Meeskond
- Joosep Ilves
- Kaspar Kallasmaa
- Siim Aaver
XML
Tõenäoliselt internetibrauser viskab XMLi ja XSLT vaatamisel errori. Sel põhjusel tuleb need enda arvutisse salvestada ja tekstiredaktoriga avada.
XSLT tulemus
Veebiteenus
Meie veebiteenus on valmistatud WCF baasil. See valik võimaldas teha teenusele formsi põhjal kasutajaliidese ja 'cache', mistõttu teeb teenus andmebaasi suunas vähem päringuid. Teenuse kasutajaliideses on logi, kuhu salvestatakse kõik meetodid ja nende parameetrid, mida kasutaja on väljakutsunud. Lisaks salvestatakse iga sekundi tagant logi ka faili.
Teenus/andmebaas on paindlik:
- Võimalik on koostada menüüsid erinevatele kuupäevadele. Näiteks saab terve nädala menüü juba ette ära määrata.
- Soodustused on seostatud kindla toiduga. Seega saab igale toidule (menüüs olemise korrale) määrata erinevad soodustused.
- Võimalik on ühe toiduga seostada 0 kuni piiramatu arv portse või soodustusi.
- Iga portsul eraldi on olemas 'saadavuse' väli. Seega on võimalik tekitada olukord, kus näiteks suur ports on otsa lõppenud aga väike veel saadaval.
Public meetodid:
* Boolean deleteUudis(int uudisId); * Boolean insertEntityUudis(EntityUudis uusUudis); * Boolean editEntityUudis(EntityUudis uusUudis); * Boolean isSuperAdmin(string id); * string getKohvikuKirjeldus(string id); * int newKohvikuKirjeldus(string kirjeldus, string id); * List<EntityKohvik> getEntityKohvikList(); * EntityKohvik getEntityKohvikById(int id); * List<EntityKaup> getAllItems(); * List<EntityKaup> getAllItemNames(); * List<EntityKaup> getItemData(int kohvikID, string date); * EntityKaup getItemByOlemineId(int olemineID); * Boolean insertItem(int kohvikID, String kategooria, String nimetus, String kuupaev, List<EntityPorts> portsud, List<EntitySoodustus> soodukad); * Boolean editItem(int olemineID, String kategooria, String nimetus, String kuupaev, List<EntityPorts> portsud, List<EntitySoodustus> soodukad); * Boolean deleteItem(int itemID, String kuupaev); * Boolean deleteItemByOlemineId(int olemineID); * Boolean toggleAvailability(int ports_ID); * List<EntityUudis> getEntityUudisList(); * List<EntityUudis> getEntityUudisListByAmount(int limit); * EntityUudis getEntityUudisById(int id); * List<EntityLahtiolekuAjad> getEntityLahtiolekuAjadByKohvikId(int kohvikId); * List<EntityKommentaar> getEntityKommentaarList(); * List<EntityKommentaar> getEntityKommentaarFor(KommentaarType kommentaarType, int id); * int getCommentCountFor(KommentaarType kommentaarType, int id); * bool addEntityKommentaarFor(KommentaarType kommentaarType, int rowIdToAddKommentaarFor, String sisu, String autor, DateTime postituseAeg); * List<EntityValuuta> getCurrency(); * int login(String user, String pass); * int getCafIdByUserId(int id); * int getUserRoleId(int userID); * List<String> getKaupNimed(int kasutaja_ID, string prefixText); * List<String> getKatNimed(string prefixText); * string EncodePassword(string originalPassword); * int lisaUusKohvik(EntityKohvik k);
Lähtekood: link
Klientrakendus
Disaini saime lehelt http://www.freewebtemplates.com
Esimene leht, mida külastaja näeb, on järgmine:
Nagu näha on vasakul üleval tulbas erinevate kohvikute nimekiri, millele klikates avaneb täpsem informatsioon valitud kohviku kohta - menüü, avamisajad, pildid jne. Alumises tulbas on kõige uuemad uudised/reklaam kohvikute kohta(näiteks: "Sõbrapäeva pakkumine, kõik joogid -15%" vms), mille all on veel link täpsema informatsiooni jaoks.
Esilehele tulles on võimalik külastajal enda asukoht lahtrisse kirjutada, mille peale otsitakse talle välja kohvik, mis asub talle kõige lähemal. Kaardil markeri peale vajutades viib antud kohviku lehele. Tavavaates on kaardil kõik kohvikud tähistatud.
Kuna meil on 3 erinevat kasutajatüüpi:
tavakasutaja - "tavaline" kohvikukülastaja
kohvikutöötaja - kes haldab oma kohviku andmeid
superadmin - saab kõigi kohvikute andmeid muuta
..siis, et kohviku(te) andmeid muuta, on vajalik admin lehelt sisse logida. Tavavaates(tavakasutajale) seda linki ei näidata, tegemist on eraldi lehega. Kui on oma parooliga sisse logitud, ilmub menüüribale "Admin" link(vt. pilt nr 2), kus on võimalik näiteks kohvikutöötajal pilte juurde lisada ja ennekõike just toite sisestada, kustutada, muuta.
Paindliku andmebaasi disaini tõttu on meil võimalik lugematul hulgal erinevaid portse ja soodustusi menüüle/toitudele lisada. Sellega lahendatakse ära see olukord, kus suur ports võib otsas olla, aga väike ports on samas olemas. Alumiselt pildilt on näha ka see, et kui antud toiduga kaasneb ka mingi soodustus, siis see uus hind kuvatakse sinna alla. Kui toit/ports on otsas, siis on see mahatõmmatud. Samuti saavad külastajad toite kommenteerida, kommentaaride hulk(arv) on näidatud toidu nimetuse taga sulgudes. Nagu alumisel pildil näha, saab külastaja erinevate päevade menüüsid sirvida(klikates kalendri ikooni peale). Toidud on kategooriatesse jaotatud, et tekiks loogiline ülesehitus.
ASP.net aine raames tegime projektile mõned täiendused. Nende kohta saab täpsemalt lugeda Meeskond "Nämm-nämm asp.net" lehelt.
Lähtekood
Kogu lähtekood on saadaval Google Codes aadressil http://code.google.com/p/kohvik/source/checkout
Kellel SVN ei ole, saab kogu projekti alla laadida siit (seisuga 04.06). Projekti käivitamisel tuleb enne tööle panna teenus ja alles seejärel klientrakendus. Selle saavutamiseks üks võimalus on määrata mitu startup projekti (visual studios paremklõps solutioni peal -> properties -> common properties -> startup project -> multiple startup projects ja määrata järjekord Teenus, Kohvik, KohvikuRax. Actioni alla määrata kas start või start without debugging). EndpointNotFoundExceptioni korral tuleb vajutada F5 (continue) ja kõik asjad peaks siiski tööle minema. See error tuleb sellepärast, et vahel läheb klientrakendus kiiremini tööle kui veebiteenus. Teenuse käivitamine nõuab adminniõigusi (Visual Studiole run as administrator).
Sisselogimiseks ITK kohviku kasutaja on test/test ja superadmin 1/1
Kokkuvõte
//TODO:
Meeskonnasisene punktide jaotus
- Joosep Ilves - 1p
- Kaspar Kallasmaa - 100p
- Siim Aaver - 58p
Logi
15. mai
muudatused.aspx ja WCF klientrakendus valmis.
10. mai
Toidu muutmise leht.
2. mai
Teenusele lisatud paar puuduvat meetodit.
18. aprill
Töötab toitude lisamise leht. Autocomplete.
16. aprill
Adminni lehel sisselogimine.
7. aprill
Teenus oskab kohvikuid ja nende andmeid puhverdada. Need on ühtlasi ka kõige tihedamini teenuselt küsitavad andmed.
2. aprill
Läksime ASMX teenuse pealt üle WCF teenusele et saaks ka andmete puhverdamise teha.
23. märts
Töötavad kohviku andmete, menüüde ja kommentaaride näitamise vaated.
9. märts
Andmebaas ülesseatud ja lisatud kirjed päringute testimiseks.
8. märts
Tõenäoliselt lõplik versioon andmebaasi disainist.
1. märts
Esialgne andmebaasi disain. Mõned tabelid ja kirjed andmebaasi, et oleks võimalik katsetada.
27. veebruar
XML fail, schema, xsl. Esialgne andmebaasi mudel.
24. veebruar
Google mapsi integreerimine rakendusse.
22. veebruar
SVN ülesseadmine, esialgne rakenduse disain.
21. veebruar
Meeskonna moodustamine, teema valimine.