Meeskond "Nämm-nämm": Difference between revisions

From ICO wiki
Jump to navigationJump to search
Kkallasm (talk | contribs)
Kkallasm (talk | contribs)
Line 91: Line 91:
''kohvikutöötaja'' - kes haldab oma kohviku andmeid<br/>
''kohvikutöötaja'' - kes haldab oma kohviku andmeid<br/>
''superadmin'' - saab kõigi kohvikute andmeid muuta<br/>
''superadmin'' - saab kõigi kohvikute andmeid muuta<br/>
..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.
..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. all pilt nr 2), kus on võimalik näiteks kohvikutöötajal pilte juurde lisada ja ennekõike just toite sisestada, kustutada, muuta.


[[File:Muutmine.PNG|thumb|center]] [[File:AdminVaade.PNG|thumb|center]]<br/>
[[File:Muutmine.PNG|thumb|center]] [[File:AdminVaade.PNG|thumb|center]]<br/>

Revision as of 18:03, 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

XML link

XSD link

XSLT link

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. all 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.