Compare commits
256 Commits
initgitflo
...
r#141
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
4a309ad980 | ||
|
|
c301f908ad | ||
|
|
6ce158dc41 | ||
|
|
e8fe0bb041 | ||
|
|
b337eefc8c | ||
|
|
70d92c7a3b | ||
|
|
363baad60c | ||
|
|
2606e089df | ||
|
|
a99ff5526c | ||
|
|
64fc09f622 | ||
|
|
a9a96b6ffc | ||
|
|
f79cd5836e | ||
|
|
d414e4df47 | ||
|
|
4652b82885 | ||
|
|
7637b62271 | ||
|
|
55e426f6c2 | ||
|
|
2eea814558 | ||
|
|
121c728df7 | ||
|
|
9a84f847d1 | ||
|
|
fa7a84661e | ||
|
|
75b6b4501f | ||
|
|
a3014d04c8 | ||
|
|
bcceaaaa53 | ||
|
|
6f5496a006 | ||
|
|
a366d0e949 | ||
|
|
88320657e9 | ||
|
|
1136e29034 | ||
|
|
759f0a8859 | ||
|
|
bf9a612de5 | ||
|
|
00fb9ca637 | ||
|
|
49151c0714 | ||
|
|
5eedf70604 | ||
|
|
c2871bb3d1 | ||
|
|
9abb7de1ec | ||
|
|
854dc8b46e | ||
|
|
96cd4bccb4 | ||
|
|
6338caea9c | ||
|
|
3874f2ef06 | ||
|
|
c12c76c5ae | ||
|
|
a3c8f3b9fc | ||
|
|
dadcc2e965 | ||
|
|
175b871005 | ||
|
|
af57bad869 | ||
|
|
932842aebb | ||
|
|
125587f99c | ||
|
|
1b52f87950 | ||
|
|
6b8ec1e8b0 | ||
|
|
5788889ae7 | ||
|
|
6b5341d1ac | ||
|
|
900cb9111a | ||
|
|
0df8f72c53 | ||
|
|
970c6ce8e8 | ||
|
|
9662be5632 | ||
|
|
6a69aec6eb | ||
|
|
dd7ef6e82e | ||
|
|
3e3b082463 | ||
|
|
4a5253c25c | ||
|
|
a375fe9008 | ||
|
|
1d434a394f | ||
|
|
5aee5e266a | ||
|
|
666b6c9730 | ||
|
|
59503f2d23 | ||
|
|
43cfeea2d7 | ||
|
|
d17b4b7e33 | ||
|
|
b78250401c | ||
|
|
d167dbfb9e | ||
|
|
0072df1186 | ||
|
|
218353393e | ||
|
|
de91ac2d76 | ||
|
|
74224a4fc5 | ||
|
|
0ceb0584d1 | ||
|
|
88b664284f | ||
|
|
92614e7128 | ||
|
|
9eff5be228 | ||
|
|
9ebeaa8147 | ||
|
|
b9f268d594 | ||
|
|
7978e27049 | ||
|
|
be65f4056b | ||
|
|
73a186cf28 | ||
|
|
7a7c478277 | ||
|
|
c886b3e573 | ||
|
|
98a51bce24 | ||
|
|
a7769184d5 | ||
|
|
40145c727e | ||
|
|
6ead6414e6 | ||
|
|
03789a9a38 | ||
|
|
92db7d16f3 | ||
|
|
9454a764d6 | ||
|
|
a433d47583 | ||
|
|
486058687d | ||
|
|
ce3c953b64 | ||
|
|
e2ee1aad9f | ||
|
|
281cd06bab | ||
|
|
d71f6db920 | ||
|
|
eb68b666f7 | ||
|
|
8a69101cbf | ||
|
|
d9a54b2b13 | ||
|
|
92d580f270 | ||
|
|
8b4ee44520 | ||
|
|
9c0415ddbb | ||
|
|
52a3154caf | ||
|
|
18f72e6096 | ||
|
|
82625f7aa4 | ||
|
|
0b82c3b18a | ||
|
|
3616bd233f | ||
|
|
573a562e03 | ||
|
|
25d6217a9b | ||
|
|
5fbd297af5 | ||
|
|
f1e41b1fce | ||
|
|
c0692dfca9 | ||
|
|
cf4c5dc486 | ||
|
|
707e7c0761 | ||
|
|
347e45f561 | ||
|
|
4395f4f6cd | ||
|
|
182b50eca2 | ||
|
|
544ae68f2c | ||
|
|
db15808e24 | ||
|
|
7e99840b6c | ||
|
|
0f82e4512d | ||
|
|
19e18a4daa | ||
|
|
2a24c01854 | ||
|
|
2ef3d053b1 | ||
|
|
c0a880e771 | ||
|
|
46cedaeeb4 | ||
|
|
bda60de4f5 | ||
|
|
e70a6d36f1 | ||
|
|
80d008a431 | ||
|
|
175765a3c0 | ||
|
|
5a709e7445 | ||
|
|
a2eeb54c55 | ||
|
|
511e6640ba | ||
|
|
505b19e57d | ||
|
|
5d2614d59b | ||
|
|
5c8756ac21 | ||
|
|
10018077fc | ||
|
|
ca13f3f581 | ||
|
|
6f1eae3ca8 | ||
|
|
8774683a80 | ||
|
|
8335c47b0f | ||
|
|
ceeaabac1c | ||
|
|
e1abe121bf | ||
|
|
ed891074e0 | ||
|
|
6dc522b6a8 | ||
|
|
b54be92e3c | ||
|
|
12acceff32 | ||
|
|
9e31f121ba | ||
|
|
a06133b173 | ||
|
|
4fa7c9d9dd | ||
|
|
e46a7a22e1 | ||
|
|
7396edc095 | ||
|
|
b6b003315f | ||
|
|
e1ea814861 | ||
|
|
579217ec1c | ||
|
|
2f247e29b4 | ||
|
|
3003508139 | ||
|
|
cb242fc2fd | ||
|
|
4f10725531 | ||
|
|
c3a572c6f6 | ||
|
|
e60bfae1a8 | ||
|
|
731e3305b9 | ||
|
|
bc77d076c9 | ||
|
|
b3ef2ab81f | ||
|
|
ea54e23d56 | ||
|
|
0f64e15c3f | ||
|
|
476a626de4 | ||
|
|
2b4b980883 | ||
|
|
086317fef5 | ||
|
|
3755348854 | ||
|
|
cc4cfd9afd | ||
|
|
7053571f6c | ||
|
|
170067df02 | ||
|
|
38becf5ae6 | ||
|
|
0e90a7a03c | ||
|
|
7e65f09ca8 | ||
|
|
7056650095 | ||
|
|
5e5074a534 | ||
|
|
f5ef147baa | ||
|
|
c9b3553d2a | ||
|
|
f8280d1ce1 | ||
|
|
448cfd5118 | ||
|
|
655b4c0638 | ||
|
|
ff39d78658 | ||
|
|
d8071e76eb | ||
|
|
2e883b1e98 | ||
|
|
5a55355f98 | ||
|
|
cfb7b74610 | ||
|
|
22a0315fdd | ||
|
|
fe46e28a26 | ||
|
|
31b4e4459e | ||
|
|
0991901c90 | ||
|
|
94a12f2a77 | ||
|
|
2b96528c7d | ||
|
|
7ee3fa5535 | ||
|
|
a8d93ee943 | ||
|
|
2a8d321a64 | ||
|
|
4b5587770c | ||
|
|
a750b5e1a2 | ||
|
|
709f7fc289 | ||
|
|
811ad35fa9 | ||
|
|
ab0ba5ac6b | ||
|
|
bb3de8beec | ||
|
|
c5ea535489 | ||
|
|
bbc6269ed1 | ||
|
|
d8b3848086 | ||
|
|
775533ec32 | ||
|
|
eb91cbae44 | ||
|
|
b52c0c8625 | ||
|
|
52872b108b | ||
|
|
d06b86bc41 | ||
|
|
c293c331fb | ||
|
|
e044450f1d | ||
|
|
ce6358b9f7 | ||
|
|
e27a8bb989 | ||
|
|
c666a526f0 | ||
|
|
6fed7482ca | ||
|
|
4d79854ee7 | ||
|
|
57da34fc6b | ||
|
|
518bbc00ce | ||
|
|
38b379c6d6 | ||
|
|
24f7607f84 | ||
|
|
55d55c64e0 | ||
|
|
8f472d7662 | ||
|
|
919c1f8d08 | ||
|
|
ff81278aba | ||
|
|
0b71ef13fe | ||
|
|
e180ca3a45 | ||
|
|
978fb9b83b | ||
|
|
fcd674aa4e | ||
|
|
7e2552a8e3 | ||
|
|
ffc902c78f | ||
|
|
5dbcc01dd2 | ||
|
|
a2463795f9 | ||
|
|
53d5fa413e | ||
|
|
5c3a8a3432 | ||
|
|
e451f7ff89 | ||
|
|
25b05855a2 | ||
|
|
52625e6bee | ||
|
|
6da4552e79 | ||
|
|
1c890fd43d | ||
|
|
f8f90ab247 | ||
|
|
0f6196a521 | ||
|
|
eac32fadd3 | ||
|
|
3d3a0fa9e2 | ||
|
|
a93ea28794 | ||
|
|
f49d1bba36 | ||
|
|
db46c1a451 | ||
|
|
7068d54406 | ||
|
|
2f4034a4f2 | ||
|
|
ec3fd17234 | ||
|
|
bff8eb07c8 | ||
|
|
512d367a7e | ||
|
|
eb533e8008 | ||
|
|
6071f96b3b | ||
|
|
72495a5bc5 | ||
|
|
84266dfb59 | ||
|
|
9c973b2b8f |
64
.gitattributes
vendored
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
###############################################################################
|
||||||
|
# Set default behavior to automatically normalize line endings.
|
||||||
|
###############################################################################
|
||||||
|
* text=auto
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# Set default behavior for command prompt diff.
|
||||||
|
#
|
||||||
|
# This is need for earlier builds of msysgit that does not have it on by
|
||||||
|
# default for csharp files.
|
||||||
|
# Note: This is only used by command line
|
||||||
|
###############################################################################
|
||||||
|
#*.cs diff=csharp
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# Set the merge driver for project and solution files
|
||||||
|
#
|
||||||
|
# Merging from the command prompt will add diff markers to the files if there
|
||||||
|
# are conflicts (Merging from VS is not affected by the settings below, in VS
|
||||||
|
# the diff markers are never inserted). Diff markers may cause the following
|
||||||
|
# file extensions to fail to load in VS. An alternative would be to treat
|
||||||
|
# these files as binary and thus will always conflict and require user
|
||||||
|
# intervention with every merge. To do so, just uncomment the entries below
|
||||||
|
###############################################################################
|
||||||
|
*.csproj -text merge=union
|
||||||
|
*.sln -text merge=union
|
||||||
|
*.resx -text merge=union
|
||||||
|
#*.vbproj merge=binary
|
||||||
|
#*.vcxproj merge=binary
|
||||||
|
#*.vcproj merge=binary
|
||||||
|
#*.dbproj merge=binary
|
||||||
|
#*.fsproj merge=binary
|
||||||
|
#*.lsproj merge=binary
|
||||||
|
#*.wixproj merge=binary
|
||||||
|
#*.modelproj merge=binary
|
||||||
|
#*.sqlproj merge=binary
|
||||||
|
#*.wwaproj merge=binary
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# behavior for image files
|
||||||
|
#
|
||||||
|
# image files are treated as binary by default.
|
||||||
|
###############################################################################
|
||||||
|
#*.jpg binary
|
||||||
|
#*.png binary
|
||||||
|
#*.gif binary
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# diff behavior for common document formats
|
||||||
|
#
|
||||||
|
# Convert binary document formats to text before diffing them. This feature
|
||||||
|
# is only available from the command line. Turn it on by uncommenting the
|
||||||
|
# entries below.
|
||||||
|
###############################################################################
|
||||||
|
#*.doc diff=astextplain
|
||||||
|
#*.DOC diff=astextplain
|
||||||
|
#*.docx diff=astextplain
|
||||||
|
#*.DOCX diff=astextplain
|
||||||
|
#*.dot diff=astextplain
|
||||||
|
#*.DOT diff=astextplain
|
||||||
|
#*.pdf diff=astextplain
|
||||||
|
#*.PDF diff=astextplain
|
||||||
|
#*.rtf diff=astextplain
|
||||||
|
#*.RTF diff=astextplain
|
||||||
194
.gitignore
vendored
Normal file
@@ -0,0 +1,194 @@
|
|||||||
|
## Ignore Visual Studio temporary files, build results, and
|
||||||
|
## files generated by popular Visual Studio add-ons.
|
||||||
|
|
||||||
|
# User-specific files
|
||||||
|
*.suo
|
||||||
|
*.user
|
||||||
|
*.sln.docstates
|
||||||
|
|
||||||
|
# Build results
|
||||||
|
|
||||||
|
[Dd]ebug/
|
||||||
|
[Rr]elease/
|
||||||
|
x64/
|
||||||
|
build/
|
||||||
|
[Bb]in/
|
||||||
|
[Oo]bj/
|
||||||
|
|
||||||
|
# MSTest test Results
|
||||||
|
[Tt]est[Rr]esult*/
|
||||||
|
[Bb]uild[Ll]og.*
|
||||||
|
|
||||||
|
*_i.c
|
||||||
|
*_p.c
|
||||||
|
*.ilk
|
||||||
|
*.meta
|
||||||
|
*.obj
|
||||||
|
*.pch
|
||||||
|
*.pdb
|
||||||
|
*.pgc
|
||||||
|
*.pgd
|
||||||
|
*.rsp
|
||||||
|
*.sbr
|
||||||
|
*.tlb
|
||||||
|
*.tli
|
||||||
|
*.tlh
|
||||||
|
*.tmp
|
||||||
|
*.tmp_proj
|
||||||
|
*.log
|
||||||
|
*.vspscc
|
||||||
|
*.vssscc
|
||||||
|
.builds
|
||||||
|
*.pidb
|
||||||
|
*.log
|
||||||
|
*.scc
|
||||||
|
|
||||||
|
# Visual C++ cache files
|
||||||
|
ipch/
|
||||||
|
*.aps
|
||||||
|
*.ncb
|
||||||
|
*.opensdf
|
||||||
|
*.sdf
|
||||||
|
*.cachefile
|
||||||
|
|
||||||
|
# Visual Studio profiler
|
||||||
|
*.psess
|
||||||
|
*.vsp
|
||||||
|
*.vspx
|
||||||
|
|
||||||
|
# Guidance Automation Toolkit
|
||||||
|
*.gpState
|
||||||
|
|
||||||
|
# ReSharper is a .NET coding add-in
|
||||||
|
_ReSharper*/
|
||||||
|
*.[Rr]e[Ss]harper
|
||||||
|
|
||||||
|
# TeamCity is a build add-in
|
||||||
|
_TeamCity*
|
||||||
|
|
||||||
|
# DotCover is a Code Coverage Tool
|
||||||
|
*.dotCover
|
||||||
|
|
||||||
|
# NCrunch
|
||||||
|
*.ncrunch*
|
||||||
|
.*crunch*.local.xml
|
||||||
|
|
||||||
|
# Installshield output folder
|
||||||
|
[Ee]xpress/
|
||||||
|
|
||||||
|
# DocProject is a documentation generator add-in
|
||||||
|
DocProject/buildhelp/
|
||||||
|
DocProject/Help/*.HxT
|
||||||
|
DocProject/Help/*.HxC
|
||||||
|
DocProject/Help/*.hhc
|
||||||
|
DocProject/Help/*.hhk
|
||||||
|
DocProject/Help/*.hhp
|
||||||
|
DocProject/Help/Html2
|
||||||
|
DocProject/Help/html
|
||||||
|
|
||||||
|
# Click-Once directory
|
||||||
|
publish/
|
||||||
|
|
||||||
|
# Publish Web Output
|
||||||
|
*.Publish.xml
|
||||||
|
*.pubxml
|
||||||
|
|
||||||
|
# NuGet Packages Directory
|
||||||
|
## TODO: If you have NuGet Package Restore enabled, uncomment the next line
|
||||||
|
#packages/
|
||||||
|
|
||||||
|
# Windows Azure Build Output
|
||||||
|
csx
|
||||||
|
*.build.csdef
|
||||||
|
|
||||||
|
# Windows Store app package directory
|
||||||
|
AppPackages/
|
||||||
|
|
||||||
|
# Others
|
||||||
|
sql/
|
||||||
|
*.Cache
|
||||||
|
ClientBin/
|
||||||
|
[Ss]tyle[Cc]op.*
|
||||||
|
~$*
|
||||||
|
*~
|
||||||
|
*.dbmdl
|
||||||
|
*.[Pp]ublish.xml
|
||||||
|
*.pfx
|
||||||
|
*.publishsettings
|
||||||
|
|
||||||
|
# RIA/Silverlight projects
|
||||||
|
Generated_Code/
|
||||||
|
|
||||||
|
# Backup & report files from converting an old project file to a newer
|
||||||
|
# Visual Studio version. Backup files are not needed, because we have git ;-)
|
||||||
|
_UpgradeReport_Files/
|
||||||
|
Backup*/
|
||||||
|
UpgradeLog*.XML
|
||||||
|
UpgradeLog*.htm
|
||||||
|
|
||||||
|
# SQL Server files
|
||||||
|
App_Data/*.mdf
|
||||||
|
App_Data/*.ldf
|
||||||
|
|
||||||
|
|
||||||
|
#LightSwitch generated files
|
||||||
|
GeneratedArtifacts/
|
||||||
|
_Pvt_Extensions/
|
||||||
|
ModelManifest.xml
|
||||||
|
|
||||||
|
# =========================
|
||||||
|
# Windows detritus
|
||||||
|
# =========================
|
||||||
|
|
||||||
|
# Windows image file caches
|
||||||
|
Thumbs.db
|
||||||
|
ehthumbs.db
|
||||||
|
|
||||||
|
# Folder config file
|
||||||
|
Desktop.ini
|
||||||
|
|
||||||
|
# Recycle Bin used on file shares
|
||||||
|
$RECYCLE.BIN/
|
||||||
|
|
||||||
|
# Mac desktop service store files
|
||||||
|
.DS_Store
|
||||||
|
gitattributes
|
||||||
|
gitignore
|
||||||
|
winphone/
|
||||||
|
.spl
|
||||||
|
.srum
|
||||||
|
*.spl
|
||||||
|
*.srum
|
||||||
|
Doxyfile
|
||||||
|
screenshots/
|
||||||
|
CampusAppWP8/packages/WPtoolkit.4.2012.10.30/lib/sl3-wp/Microsoft.Phone.Controls.Toolkit.dll
|
||||||
|
CampusAppWP8/packages/WPtoolkit.4.2012.10.30/lib/sl4-windowsphone71/Microsoft.Phone.Controls.Toolkit.dll
|
||||||
|
CampusAppWP8/packages/WPtoolkit.4.2012.10.30/lib/wp8/Microsoft.Phone.Controls.Toolkit.dll
|
||||||
|
CampusAppWP8/packages/BuiltToRoam.Core.Agent.1.0.1.5/BuiltToRoam.Core.Agent.1.0.1.5.nupkg
|
||||||
|
CampusAppWP8/packages/BuiltToRoam.Core.Agent.1.0.1.5/BuiltToRoam.Core.Agent.1.0.1.5.nuspec
|
||||||
|
CampusAppWP8/packages/BuiltToRoam.Core.Agent.1.0.1.5/lib/sl4-wp71/AsyncCtpLibrary_Phone.dll
|
||||||
|
CampusAppWP8/packages/BuiltToRoam.Core.Agent.1.0.1.5/lib/sl4-wp71/BuiltToRoam.Core.Agent.dll
|
||||||
|
CampusAppWP8/packages/BuiltToRoam.GeoWatcher.1.0.1.5/BuiltToRoam.GeoWatcher.1.0.1.5.nupkg
|
||||||
|
CampusAppWP8/packages/BuiltToRoam.GeoWatcher.1.0.1.5/BuiltToRoam.GeoWatcher.1.0.1.5.nuspec
|
||||||
|
CampusAppWP8/packages/BuiltToRoam.GeoWatcher.1.0.1.5/lib/sl4-wp71/BuiltToRoam.GeoWatcher.dll
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/Newtonsoft.Json.4.5.11.nupkg
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/Newtonsoft.Json.4.5.11.nuspec
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/net20/Newtonsoft.Json.dll
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/net20/Newtonsoft.Json.xml
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/net35/Newtonsoft.Json.dll
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/net35/Newtonsoft.Json.xml
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/net40/Newtonsoft.Json.dll
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/net40/Newtonsoft.Json.xml
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/portable-net40+sl4+wp7+win8/Newtonsoft.Json.dll
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/portable-net40+sl4+wp7+win8/Newtonsoft.Json.xml
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/sl3-wp/Newtonsoft.Json.dll
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/sl3-wp/Newtonsoft.Json.xml
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/sl4-windowsphone71/Newtonsoft.Json.dll
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/sl4-windowsphone71/Newtonsoft.Json.xml
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/sl4/Newtonsoft.Json.dll
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/sl4/Newtonsoft.Json.xml
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/winrt45/Newtonsoft.Json.dll
|
||||||
|
CampusAppWP8/packages/Newtonsoft.Json.4.5.11/lib/winrt45/Newtonsoft.Json.xml
|
||||||
|
CampusAppWP8/packages/SharpZipLib-WP7.0.86.0.518/SharpZipLib-WP7.0.86.0.518.nupkg
|
||||||
|
CampusAppWP8/packages/SharpZipLib-WP7.0.86.0.518/SharpZipLib-WP7.0.86.0.518.nuspec
|
||||||
|
CampusAppWP8/packages/SharpZipLib-WP7.0.86.0.518/lib/sl4-windowsphone71/SharpZipLib.WindowsPhone7.dll
|
||||||
27
CampusAppWP8/CampusAppWP8/Api/GeoApi/SpsApi.cs
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="SpsApi.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>06.08.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.Feed.GeoApi
|
||||||
|
{
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.GeoDb;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Class for SPSAPI
|
||||||
|
/// </summary>
|
||||||
|
public class SpsApi : XmlModel<SpsModel>
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="SpsApi" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public SpsApi()
|
||||||
|
: base(ModelType.Feed, Constants.UrlSpsService)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
31
CampusAppWP8/CampusAppWP8/Api/Lecture/LectureApi.cs
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="LectureApi.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>13.06.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.Feed.Lecture
|
||||||
|
{
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.Lecture;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Class for the feed of the Lecture
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// need the XmlAPI
|
||||||
|
/// </remarks>
|
||||||
|
public class LectureApi : XmlModel<LectureList>
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="LectureApi" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public LectureApi()
|
||||||
|
: base(ModelType.Feed, Constants.UrlLecture_ApiBaseAddr)
|
||||||
|
{
|
||||||
|
this.ValidRootName = Constants.LectureXmlValidRootName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -8,12 +8,22 @@
|
|||||||
|
|
||||||
<!--Anwendungsressourcen-->
|
<!--Anwendungsressourcen-->
|
||||||
<Application.Resources>
|
<Application.Resources>
|
||||||
<local:LocalizedStrings xmlns:local="clr-namespace:CampusAppWP8" x:Key="LocalizedStrings"/>
|
<ResourceDictionary>
|
||||||
|
<ResourceDictionary.MergedDictionaries>
|
||||||
|
<ResourceDictionary Source="Styles/ListButton.xaml"/>
|
||||||
|
<ResourceDictionary Source="Styles/StartPageStyles.xaml"/>
|
||||||
|
<ResourceDictionary>
|
||||||
|
<local:LocalizedStrings xmlns:local="clr-namespace:CampusAppWP8" x:Key="LocalizedStrings"/>
|
||||||
|
<local:ThemelizedIcons xmlns:local="clr-namespace:CampusAppWP8" x:Key="ThemelizedIcons"/>
|
||||||
|
<local:Const xmlns:local="clr-namespace:CampusAppWP8" x:Key="Const"/>
|
||||||
|
</ResourceDictionary>
|
||||||
|
</ResourceDictionary.MergedDictionaries>
|
||||||
|
</ResourceDictionary>
|
||||||
</Application.Resources>
|
</Application.Resources>
|
||||||
|
|
||||||
<Application.ApplicationLifetimeObjects>
|
<Application.ApplicationLifetimeObjects>
|
||||||
<!--Erforderliches Objekt, das Lebensdauerereignisse der Anwendung behandelt-->
|
<!--Erforderliches Objekt, das Lebensdauerereignisse der Anwendung behandelt-->
|
||||||
<shell:PhoneApplicationService
|
<shell:PhoneApplicationService
|
||||||
Launching="Application_Launching" Closing="Application_Closing"
|
Launching="Application_Launching" Closing="Application_Closing"
|
||||||
Activated="Application_Activated" Deactivated="Application_Deactivated"/>
|
Activated="Application_Activated" Deactivated="Application_Deactivated"/>
|
||||||
</Application.ApplicationLifetimeObjects>
|
</Application.ApplicationLifetimeObjects>
|
||||||
|
|||||||
@@ -1,13 +1,18 @@
|
|||||||
using System;
|
using CampusAppWP8.File.Setting;
|
||||||
|
using CampusAppWP8.Model.Setting;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
using CampusAppWP8.Utility;
|
||||||
|
using Microsoft.Phone.Controls;
|
||||||
|
using Microsoft.Phone.Shell;
|
||||||
|
using System;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Resources;
|
using System.Globalization;
|
||||||
|
using System.IO.IsolatedStorage;
|
||||||
|
using System.Threading;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Markup;
|
using System.Windows.Markup;
|
||||||
using System.Windows.Navigation;
|
using System.Windows.Navigation;
|
||||||
using Microsoft.Phone.Controls;
|
using Windows.Devices.Geolocation;
|
||||||
using Microsoft.Phone.Shell;
|
|
||||||
using CampusAppWP8.Resources;
|
|
||||||
using System.IO.IsolatedStorage;
|
|
||||||
|
|
||||||
|
|
||||||
namespace CampusAppWP8
|
namespace CampusAppWP8
|
||||||
@@ -85,22 +90,91 @@ namespace CampusAppWP8
|
|||||||
{
|
{
|
||||||
IsolatedStorageSettings isolatedStore = IsolatedStorageSettings.ApplicationSettings;
|
IsolatedStorageSettings isolatedStore = IsolatedStorageSettings.ApplicationSettings;
|
||||||
|
|
||||||
if(isolatedStore.Contains(key)) {
|
if (isolatedStore.Contains(key))
|
||||||
|
{
|
||||||
object value = isolatedStore[key];
|
object value = isolatedStore[key];
|
||||||
return (T)value;
|
return (T)value;
|
||||||
}
|
}
|
||||||
return default(T);
|
return default(T);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method save any object to the IsolatedStorage
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key"> key of the object</param>
|
||||||
|
/// <param name="value">value of the object, if value == null => remove key</param>
|
||||||
|
public static void SaveToAppState<T>(string key, T value)
|
||||||
|
{
|
||||||
|
IsolatedStorageSettings isolatedStore = IsolatedStorageSettings.ApplicationSettings;
|
||||||
|
isolatedStore.Remove(key);
|
||||||
|
if (value != null)
|
||||||
|
{
|
||||||
|
isolatedStore.Add(key, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
isolatedStore.Save();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method load any object to the IsolatedStorage
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key"> key of the object</param>
|
||||||
|
public static T LoadFromAppState<T>(string key)
|
||||||
|
{
|
||||||
|
IsolatedStorageSettings isolatedStore = IsolatedStorageSettings.ApplicationSettings;
|
||||||
|
|
||||||
|
if (isolatedStore.Contains(key))
|
||||||
|
{
|
||||||
|
object value = isolatedStore[key];
|
||||||
|
return (T)value;
|
||||||
|
}
|
||||||
|
return default(T);
|
||||||
|
}
|
||||||
|
|
||||||
// Code, der beim Starten der Anwendung ausgeführt werden soll (z. B. über "Start")
|
// Code, der beim Starten der Anwendung ausgeführt werden soll (z. B. über "Start")
|
||||||
// Dieser Code wird beim Reaktivieren der Anwendung nicht ausgeführt
|
// Dieser Code wird beim Reaktivieren der Anwendung nicht ausgeführt
|
||||||
private void Application_Launching(object sender, LaunchingEventArgs e)
|
private void Application_Launching(object sender, LaunchingEventArgs e)
|
||||||
{
|
{
|
||||||
|
this.LoadSettings();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Load the appsettings from the store
|
||||||
|
/// </summary>
|
||||||
|
private void LoadSettings()
|
||||||
|
{
|
||||||
|
UserProfilFile userFile;
|
||||||
|
userFile = Settings.UserProfil;
|
||||||
|
if (userFile.Model == null)
|
||||||
|
{
|
||||||
|
userFile.onLoaded += new UserProfilFile.OnLoaded(this.UserSettingsLoaded);
|
||||||
|
userFile.LoadData();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this.UserSettingsLoaded();
|
||||||
|
}
|
||||||
|
|
||||||
|
Thread thread = new Thread(new ThreadStart(Utilities.DetermineAndStoreCurrentPosition));
|
||||||
|
thread.Start();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Load the usersettings from the store
|
||||||
|
/// </summary>
|
||||||
|
private void UserSettingsLoaded()
|
||||||
|
{
|
||||||
|
if (Settings.UserProfil.Model == null)
|
||||||
|
{
|
||||||
|
Settings.UserProfil.Model = new UserProfilModel();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Code, der ausgeführt werden soll, wenn die Anwendung aktiviert wird (in den Vordergrund gebracht wird)
|
// Code, der ausgeführt werden soll, wenn die Anwendung aktiviert wird (in den Vordergrund gebracht wird)
|
||||||
// Dieser Code wird beim ersten Starten der Anwendung nicht ausgeführt
|
// Dieser Code wird beim ersten Starten der Anwendung nicht ausgeführt
|
||||||
private void Application_Activated(object sender, ActivatedEventArgs e)
|
private void Application_Activated(object sender, ActivatedEventArgs e)
|
||||||
{
|
{
|
||||||
|
this.LoadSettings();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 5.1 KiB After Width: | Height: | Size: 3.9 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/DarkTheme/btulogo_159.png
Normal file
|
After Width: | Height: | Size: 6.2 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/DarkTheme/campus_159.png
Normal file
|
After Width: | Height: | Size: 5.2 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/DarkTheme/delete_159.png
Normal file
|
After Width: | Height: | Size: 6.1 KiB |
|
After Width: | Height: | Size: 5.4 KiB |
|
After Width: | Height: | Size: 7.5 KiB |
|
After Width: | Height: | Size: 8.9 KiB |
|
Before Width: | Height: | Size: 5.1 KiB After Width: | Height: | Size: 5.0 KiB |
|
After Width: | Height: | Size: 7.7 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/DarkTheme/link_159.png
Normal file
|
After Width: | Height: | Size: 8.2 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/DarkTheme/mensa_159.png
Normal file
|
After Width: | Height: | Size: 9.0 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/DarkTheme/news_159.png
Normal file
|
After Width: | Height: | Size: 6.9 KiB |
|
After Width: | Height: | Size: 9.2 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/DarkTheme/phone_159.png
Normal file
|
After Width: | Height: | Size: 6.4 KiB |
|
After Width: | Height: | Size: 6.7 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/DarkTheme/search_159.png
Normal file
|
After Width: | Height: | Size: 7.3 KiB |
|
After Width: | Height: | Size: 7.3 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/DarkTheme/webmail_159.png
Normal file
|
After Width: | Height: | Size: 6.4 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/LightTheme/add_159.png
Normal file
|
After Width: | Height: | Size: 3.8 KiB |
|
After Width: | Height: | Size: 5.6 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/LightTheme/campus_159.png
Normal file
|
After Width: | Height: | Size: 5.7 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/LightTheme/delete_159.png
Normal file
|
After Width: | Height: | Size: 6.6 KiB |
|
After Width: | Height: | Size: 5.6 KiB |
|
After Width: | Height: | Size: 8.4 KiB |
|
After Width: | Height: | Size: 10 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/LightTheme/info_159.png
Normal file
|
After Width: | Height: | Size: 5.2 KiB |
|
After Width: | Height: | Size: 8.5 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/LightTheme/link_159.png
Normal file
|
After Width: | Height: | Size: 9.3 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/LightTheme/mensa_159.png
Normal file
|
After Width: | Height: | Size: 10 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/LightTheme/news_159.png
Normal file
|
After Width: | Height: | Size: 7.5 KiB |
|
After Width: | Height: | Size: 11 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/LightTheme/phone_159.png
Normal file
|
After Width: | Height: | Size: 7.0 KiB |
|
After Width: | Height: | Size: 6.6 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Icons/LightTheme/search_159.png
Normal file
|
After Width: | Height: | Size: 8.1 KiB |
|
After Width: | Height: | Size: 8.1 KiB |
|
After Width: | Height: | Size: 6.9 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Tiles/kachel_large.png
Normal file
|
After Width: | Height: | Size: 21 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Tiles/kachel_medium.png
Normal file
|
After Width: | Height: | Size: 19 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/Tiles/kachel_small.png
Normal file
|
After Width: | Height: | Size: 9.5 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/icons/DarkTheme/update_159.png
Normal file
|
After Width: | Height: | Size: 6.8 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/icons/LightTheme/update_159.png
Normal file
|
After Width: | Height: | Size: 7.4 KiB |
|
Before Width: | Height: | Size: 5.4 KiB |
|
Before Width: | Height: | Size: 5.5 KiB |
|
Before Width: | Height: | Size: 9.2 KiB |
|
Before Width: | Height: | Size: 9.0 KiB |
|
Before Width: | Height: | Size: 7.6 KiB |
|
Before Width: | Height: | Size: 7.3 KiB |
|
Before Width: | Height: | Size: 8.5 KiB |
|
Before Width: | Height: | Size: 7.9 KiB |
|
Before Width: | Height: | Size: 9.2 KiB |
|
Before Width: | Height: | Size: 8.8 KiB |
|
Before Width: | Height: | Size: 7.1 KiB |
|
Before Width: | Height: | Size: 6.7 KiB |
|
Before Width: | Height: | Size: 9.5 KiB |
|
Before Width: | Height: | Size: 9.1 KiB |
|
Before Width: | Height: | Size: 6.9 KiB |
|
Before Width: | Height: | Size: 6.0 KiB |
|
Before Width: | Height: | Size: 7.5 KiB |
|
Before Width: | Height: | Size: 7.0 KiB |
|
Before Width: | Height: | Size: 6.5 KiB |
|
Before Width: | Height: | Size: 6.2 KiB |
BIN
CampusAppWP8/CampusAppWP8/Assets/testmap.png
Normal file
|
After Width: | Height: | Size: 10 KiB |
@@ -93,29 +93,74 @@
|
|||||||
<WarningLevel>4</WarningLevel>
|
<WarningLevel>4</WarningLevel>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<Compile Include="Api\GeoApi\SpsApi.cs" />
|
||||||
<Compile Include="App.xaml.cs">
|
<Compile Include="App.xaml.cs">
|
||||||
<DependentUpon>App.xaml</DependentUpon>
|
<DependentUpon>App.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="Feed\Departments\DepartmentFavoriteFeed.cs" />
|
||||||
|
<Compile Include="Const.cs" />
|
||||||
|
<Compile Include="File\Setting\UserProfilFile.cs" />
|
||||||
|
<Compile Include="Model\GeoDb\PlaceModel.cs" />
|
||||||
|
<Compile Include="Model\GeoDb\SpsModel.cs" />
|
||||||
|
<Compile Include="Model\Mensa\MealModel.cs" />
|
||||||
|
<Compile Include="Model\Setting\AppSettings.cs" />
|
||||||
|
<Compile Include="Model\Setting\UserProfilModel.cs" />
|
||||||
|
<Compile Include="Model\Utility\CourseListPickerItemListModel.cs" />
|
||||||
|
<Compile Include="Model\Utility\DegreeListPickerItemListModel.cs" />
|
||||||
|
<Compile Include="Model\Utility\CleanUrlParamModel.cs" />
|
||||||
|
<Compile Include="Model\Utility\RoleListPickerItemListModel.cs" />
|
||||||
|
<Compile Include="Model\Utility\SemesterListPickerItemListModel.cs" />
|
||||||
|
<Compile Include="Model\Utility\ListPickerItemListModel.cs" />
|
||||||
|
<Compile Include="Pages\Setting\UserProfil.xaml.cs">
|
||||||
|
<DependentUpon>UserProfil.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Resources\Icons.Designer.cs" />
|
||||||
|
<Compile Include="Settings.cs" />
|
||||||
|
<Compile Include="Utility\Lui\Button\EmailButton.cs" />
|
||||||
|
<Compile Include="Feed\Link\CommonLinkFeed.cs" />
|
||||||
|
<Compile Include="Feed\Link\ClubLinkFeed.cs" />
|
||||||
|
<Compile Include="Feed\Openinghours\OpeninghoursFeed.cs" />
|
||||||
|
<Compile Include="Feed\StudentCouncil\StudentCouncilFeed.cs" />
|
||||||
<Compile Include="LocalizedStrings.cs" />
|
<Compile Include="LocalizedStrings.cs" />
|
||||||
|
<Compile Include="Model\Campusmap\MapModel.cs" />
|
||||||
|
<Compile Include="Model\Campusmap\MapPinModel.cs" />
|
||||||
<Compile Include="Model\Departments\ChairModel.cs" />
|
<Compile Include="Model\Departments\ChairModel.cs" />
|
||||||
<Compile Include="Model\Departments\DepartmentModel.cs" />
|
<Compile Include="Model\Departments\DepartmentModel.cs" />
|
||||||
<Compile Include="Model\Departments\DepartmentViewModel.cs" />
|
|
||||||
<Compile Include="Model\Departments\FacultyModel.cs" />
|
<Compile Include="Model\Departments\FacultyModel.cs" />
|
||||||
<Compile Include="Model\Events\RSSChannelModel.cs" />
|
<Compile Include="Model\RSS\RSSChannelModel.cs" />
|
||||||
<Compile Include="Model\Events\RSSViewModel.cs" />
|
<Compile Include="Model\RSS\RSSViewModel.cs" />
|
||||||
<Compile Include="Model\Lecture\LectureActivity.cs" />
|
<Compile Include="Model\Lecture\LectureActivity.cs" />
|
||||||
<Compile Include="Model\Lecture\LectureCourse.cs" />
|
<Compile Include="Model\Lecture\LectureCourse.cs" />
|
||||||
<Compile Include="Model\Lecture\LectureDate.cs" />
|
<Compile Include="Model\Lecture\LectureDate.cs" />
|
||||||
<Compile Include="Model\Lecture\LectureLecturer.cs" />
|
<Compile Include="Model\Lecture\LectureLecturer.cs" />
|
||||||
<Compile Include="Model\Lecture\LectureList.cs" />
|
<Compile Include="Model\Lecture\LectureList.cs" />
|
||||||
<Compile Include="Model\Lecture\LectureModul.cs" />
|
<Compile Include="Model\Lecture\LectureModule.cs" />
|
||||||
|
<Compile Include="Model\Lecture\LecturePageModel.cs" />
|
||||||
|
<Compile Include="Model\MainModel.cs" />
|
||||||
|
<Compile Include="Model\Link\LinkModel.cs" />
|
||||||
|
<Compile Include="Model\Link\LinkListModel.cs" />
|
||||||
<Compile Include="Model\Mensa\MenuModel.cs" />
|
<Compile Include="Model\Mensa\MenuModel.cs" />
|
||||||
<Compile Include="Model\Mensa\MenuWeekModel.cs" />
|
<Compile Include="Model\Mensa\MenuWeekModel.cs" />
|
||||||
|
<Compile Include="Model\Openinghours\OpeninghoursInstitutionModel.cs" />
|
||||||
|
<Compile Include="Model\Openinghours\OpeninghoursModel.cs" />
|
||||||
|
<Compile Include="Model\StudentCouncil\StudentCouncilListModel.cs" />
|
||||||
|
<Compile Include="Model\StudentCouncil\StudentCouncilModel.cs" />
|
||||||
|
<Compile Include="Model\Utility\UrlParamModel.cs" />
|
||||||
|
<Compile Include="Model\XmlModel.cs" />
|
||||||
<Compile Include="Pages\Campusmap\CampusMapPage.xaml.cs">
|
<Compile Include="Pages\Campusmap\CampusMapPage.xaml.cs">
|
||||||
<DependentUpon>CampusMapPage.xaml</DependentUpon>
|
<DependentUpon>CampusMapPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
<Compile Include="Pages\Lecture\LectureFeed.cs" />
|
<Compile Include="Api\Lecture\LectureApi.cs" />
|
||||||
<Compile Include="Feed\Departments\DepartmentFeed.cs" />
|
<Compile Include="Feed\Departments\DepartmentFeed.cs" />
|
||||||
|
<Compile Include="Pages\Departments\DepartmentFavoritePage.xaml.cs">
|
||||||
|
<DependentUpon>DepartmentFavoritePage.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Pages\Departments\DepartmentIndexPage.xaml.cs">
|
||||||
|
<DependentUpon>DepartmentIndexPage.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Pages\Departments\DepartmentInfoPage.xaml.cs">
|
||||||
|
<DependentUpon>DepartmentInfoPage.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="Pages\Departments\DepartmentPage.xaml.cs">
|
<Compile Include="Pages\Departments\DepartmentPage.xaml.cs">
|
||||||
<DependentUpon>DepartmentPage.xaml</DependentUpon>
|
<DependentUpon>DepartmentPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
@@ -126,21 +171,23 @@
|
|||||||
<Compile Include="Pages\Events\EventPage.xaml.cs">
|
<Compile Include="Pages\Events\EventPage.xaml.cs">
|
||||||
<DependentUpon>EventPage.xaml</DependentUpon>
|
<DependentUpon>EventPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
<Compile Include="pages\lecture\LecturePage.xaml.cs">
|
<Compile Include="Pages\Lecture\LecturePage.xaml.cs">
|
||||||
<DependentUpon>LecturePage.xaml</DependentUpon>
|
<DependentUpon>LecturePage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
<Compile Include="Model\BaseModel.cs" />
|
|
||||||
<Compile Include="Model\BaseViewModel.cs" />
|
|
||||||
<Compile Include="Feed\Mensa\MensaFeed.cs" />
|
<Compile Include="Feed\Mensa\MensaFeed.cs" />
|
||||||
<Compile Include="Pages\Lecture\ModulWebPage.xaml.cs">
|
<Compile Include="Pages\Lecture\ModulWebPage.xaml.cs">
|
||||||
<DependentUpon>ModulWebPage.xaml</DependentUpon>
|
<DependentUpon>ModulWebPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="Model\Utility\ListPickerItemModel.cs" />
|
||||||
<Compile Include="Pages\Lecture\ResultDetailPage.xaml.cs">
|
<Compile Include="Pages\Lecture\ResultDetailPage.xaml.cs">
|
||||||
<DependentUpon>ResultDetailPage.xaml</DependentUpon>
|
<DependentUpon>ResultDetailPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
<Compile Include="Pages\Lecture\ResultPage.xaml.cs">
|
<Compile Include="Pages\Lecture\ResultPage.xaml.cs">
|
||||||
<DependentUpon>ResultPage.xaml</DependentUpon>
|
<DependentUpon>ResultPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="Pages\Links\LinkPage.xaml.cs">
|
||||||
|
<DependentUpon>LinkPage.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="Pages\Mensa\MensaPage.xaml.cs">
|
<Compile Include="Pages\Mensa\MensaPage.xaml.cs">
|
||||||
<DependentUpon>MensaPage.xaml</DependentUpon>
|
<DependentUpon>MensaPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
@@ -151,10 +198,16 @@
|
|||||||
<Compile Include="Pages\News\NewsPage.xaml.cs">
|
<Compile Include="Pages\News\NewsPage.xaml.cs">
|
||||||
<DependentUpon>NewsPage.xaml</DependentUpon>
|
<DependentUpon>NewsPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
<Compile Include="Model\Events\RSSModel.cs" />
|
<Compile Include="Model\RSS\RSSModel.cs" />
|
||||||
<Compile Include="pages\StartPage.xaml.cs">
|
<Compile Include="Pages\Openinghours\OpeninghoursPage.xaml.cs">
|
||||||
|
<DependentUpon>OpeninghoursPage.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Pages\StartPage.xaml.cs">
|
||||||
<DependentUpon>StartPage.xaml</DependentUpon>
|
<DependentUpon>StartPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="Pages\StudentCouncil\StudentCouncilPage.xaml.cs">
|
||||||
|
<DependentUpon>StudentCouncilPage.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="Pages\Webmail\WebmailPage.xaml.cs">
|
<Compile Include="Pages\Webmail\WebmailPage.xaml.cs">
|
||||||
<DependentUpon>WebmailPage.xaml</DependentUpon>
|
<DependentUpon>WebmailPage.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
@@ -169,15 +222,21 @@
|
|||||||
<DesignTime>True</DesignTime>
|
<DesignTime>True</DesignTime>
|
||||||
<DependentUpon>Constants.resx</DependentUpon>
|
<DependentUpon>Constants.resx</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
<Compile Include="Utility\Feed.cs" />
|
<Compile Include="ThemelizedIcons.cs" />
|
||||||
<Compile Include="Utility\FeedEventHandler.cs" />
|
<Compile Include="Utility\File.cs" />
|
||||||
<Compile Include="Utility\FileList.cs" />
|
|
||||||
<Compile Include="Utility\FileManager.cs" />
|
|
||||||
<Compile Include="Utility\Logger.cs" />
|
<Compile Include="Utility\Logger.cs" />
|
||||||
<Compile Include="Utility\RestApi.cs" />
|
<Compile Include="Utility\HttpRequest.cs" />
|
||||||
|
<Compile Include="Utility\Lui\Button\GoToMapButton.cs" />
|
||||||
|
<Compile Include="Utility\Lui\Button\UpdateButtonAppBar.cs" />
|
||||||
|
<Compile Include="Utility\Lui\Button\ToggleButton.cs" />
|
||||||
|
<Compile Include="Utility\Lui\Button\NavigateButton.cs" />
|
||||||
|
<Compile Include="Utility\Lui\Button\PhoneButton.cs" />
|
||||||
|
<Compile Include="Utility\Lui\Button\LinkButton.cs" />
|
||||||
<Compile Include="Utility\StringManager.cs" />
|
<Compile Include="Utility\StringManager.cs" />
|
||||||
<Compile Include="Utility\URLList.cs" />
|
<Compile Include="Utility\Utilities.cs">
|
||||||
<Compile Include="Utility\XmlFeed.cs" />
|
<SubType>Code</SubType>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Utility\XmlManager.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ApplicationDefinition Include="App.xaml">
|
<ApplicationDefinition Include="App.xaml">
|
||||||
@@ -188,6 +247,18 @@
|
|||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
</Page>
|
</Page>
|
||||||
|
<Page Include="Pages\Departments\DepartmentFavoritePage.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
|
<Page Include="Pages\Departments\DepartmentIndexPage.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
|
<Page Include="Pages\Departments\DepartmentInfoPage.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
<Page Include="Pages\Departments\DepartmentPage.xaml">
|
<Page Include="Pages\Departments\DepartmentPage.xaml">
|
||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
@@ -216,6 +287,10 @@
|
|||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
</Page>
|
</Page>
|
||||||
|
<Page Include="Pages\Links\LinkPage.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
<Page Include="Pages\Mensa\MensaPage.xaml">
|
<Page Include="Pages\Mensa\MensaPage.xaml">
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
@@ -228,14 +303,34 @@
|
|||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
</Page>
|
</Page>
|
||||||
|
<Page Include="Pages\Openinghours\OpeninghoursPage.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
|
<Page Include="Pages\Setting\UserProfil.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
<Page Include="pages\StartPage.xaml">
|
<Page Include="pages\StartPage.xaml">
|
||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
</Page>
|
</Page>
|
||||||
|
<Page Include="Pages\StudentCouncil\StudentCouncilPage.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
<Page Include="Pages\Webmail\WebmailPage.xaml">
|
<Page Include="Pages\Webmail\WebmailPage.xaml">
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
</Page>
|
</Page>
|
||||||
|
<Page Include="Styles\StartPageStyles.xaml">
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
</Page>
|
||||||
|
<Page Include="Styles\ListButton.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="Assets\psd\holo_optionsbuttons.psd" />
|
<None Include="Assets\psd\holo_optionsbuttons.psd" />
|
||||||
@@ -251,28 +346,45 @@
|
|||||||
<Content Include="Assets\ApplicationIcon.png">
|
<Content Include="Assets\ApplicationIcon.png">
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
<Content Include="Assets\icons\campus_159_dark.png" />
|
<Content Include="Assets\Icons\DarkTheme\add_159.png" />
|
||||||
<Content Include="Assets\icons\campus_159_light.png" />
|
<Content Include="Assets\Icons\DarkTheme\btulogo_159.png" />
|
||||||
<Content Include="Assets\icons\departments_159_dark.png" />
|
<Content Include="Assets\Icons\DarkTheme\campus_159.png" />
|
||||||
<Content Include="Assets\icons\departments_159_light.png" />
|
<Content Include="Assets\Icons\DarkTheme\delete_159.png" />
|
||||||
<Content Include="Assets\icons\homework_159_dark.png" />
|
<Content Include="Assets\Icons\DarkTheme\favorite_159.png" />
|
||||||
<Content Include="Assets\icons\homework_159_light.png" />
|
<Content Include="Assets\Icons\DarkTheme\info_159.png" />
|
||||||
<Content Include="Assets\icons\link_159_dark.png" />
|
<Content Include="Assets\Icons\DarkTheme\phone_159.png" />
|
||||||
<Content Include="Assets\icons\link_159_light.png" />
|
<Content Include="Assets\Icons\DarkTheme\update_159.png" />
|
||||||
<Content Include="Assets\icons\lectures_159_dark.png" />
|
<Content Include="Assets\Icons\LightTheme\add_159.png" />
|
||||||
<Content Include="Assets\icons\lectures_159_light.png" />
|
<Content Include="Assets\Icons\LightTheme\btulogo_159.png" />
|
||||||
<Content Include="Assets\icons\mensa_159_dark.png" />
|
<Content Include="Assets\Icons\LightTheme\campus_159.png" />
|
||||||
<Content Include="Assets\icons\mensa_159_light.png" />
|
<Content Include="Assets\Icons\DarkTheme\departments_159.png" />
|
||||||
<Content Include="Assets\icons\news_159_dark.png" />
|
<Content Include="Assets\Icons\LightTheme\delete_159.png" />
|
||||||
<Content Include="Assets\icons\news_159_light.png" />
|
<Content Include="Assets\Icons\LightTheme\departments_159.png" />
|
||||||
<Content Include="Assets\icons\openhours_159_dark.png" />
|
<Content Include="Assets\Icons\DarkTheme\homework_159.png" />
|
||||||
<Content Include="Assets\icons\openhours_159_light.png" />
|
<Content Include="Assets\Icons\LightTheme\favorite_159.png" />
|
||||||
<Content Include="Assets\icons\schedule_159_dark.png" />
|
<Content Include="Assets\Icons\LightTheme\homework_159.png" />
|
||||||
<Content Include="Assets\icons\schedule_159_light.png" />
|
<Content Include="Assets\Icons\DarkTheme\link_159.png" />
|
||||||
<Content Include="Assets\icons\student_council_159_dark.png" />
|
<Content Include="Assets\Icons\LightTheme\info_159.png" />
|
||||||
<Content Include="Assets\icons\student_council_159_light.png" />
|
<Content Include="Assets\Icons\LightTheme\link_159.png" />
|
||||||
<Content Include="Assets\icons\webmail_159_dark.png" />
|
<Content Include="Assets\Icons\DarkTheme\lectures_159.png" />
|
||||||
<Content Include="Assets\icons\webmail_159_light.png" />
|
<Content Include="Assets\Icons\LightTheme\lectures_159.png" />
|
||||||
|
<Content Include="Assets\Icons\DarkTheme\mensa_159.png" />
|
||||||
|
<Content Include="Assets\Icons\LightTheme\mensa_159.png" />
|
||||||
|
<Content Include="Assets\Icons\DarkTheme\news_159.png" />
|
||||||
|
<Content Include="Assets\Icons\LightTheme\news_159.png" />
|
||||||
|
<Content Include="Assets\Icons\DarkTheme\openhours_159.png" />
|
||||||
|
<Content Include="Assets\Icons\LightTheme\openhours_159.png" />
|
||||||
|
<Content Include="Assets\Icons\DarkTheme\schedule_159.png" />
|
||||||
|
<Content Include="Assets\Icons\LightTheme\phone_159.png" />
|
||||||
|
<Content Include="Assets\Icons\LightTheme\schedule_159.png" />
|
||||||
|
<Content Include="Assets\Icons\DarkTheme\search_159.png" />
|
||||||
|
<Content Include="Assets\Icons\LightTheme\search_159.png" />
|
||||||
|
<Content Include="Assets\Icons\DarkTheme\student_council_159.png" />
|
||||||
|
<Content Include="Assets\Icons\LightTheme\student_council_159.png" />
|
||||||
|
<Content Include="Assets\Icons\DarkTheme\webmail_159.png" />
|
||||||
|
<Content Include="Assets\Icons\LightTheme\update_159.png" />
|
||||||
|
<Content Include="Assets\Icons\LightTheme\webmail_159.png" />
|
||||||
|
<Content Include="Assets\testmap.png" />
|
||||||
<Content Include="Assets\Tiles\FlipCycleTileLarge.png">
|
<Content Include="Assets\Tiles\FlipCycleTileLarge.png">
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
@@ -288,6 +400,9 @@
|
|||||||
<Content Include="Assets\Tiles\IconicTileSmall.png">
|
<Content Include="Assets\Tiles\IconicTileSmall.png">
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
|
<Content Include="Assets\Tiles\kachel_large.png" />
|
||||||
|
<Content Include="Assets\Tiles\kachel_medium.png" />
|
||||||
|
<Content Include="Assets\Tiles\kachel_small.png" />
|
||||||
<Content Include="README_FIRST.txt" />
|
<Content Include="README_FIRST.txt" />
|
||||||
<Content Include="Toolkit.Content\ApplicationBar.Cancel.png" />
|
<Content Include="Toolkit.Content\ApplicationBar.Cancel.png" />
|
||||||
<Content Include="Toolkit.Content\ApplicationBar.Check.png" />
|
<Content Include="Toolkit.Content\ApplicationBar.Check.png" />
|
||||||
@@ -301,15 +416,34 @@
|
|||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
</EmbeddedResource>
|
</EmbeddedResource>
|
||||||
<EmbeddedResource Include="Resources\Constants.resx">
|
<EmbeddedResource Include="Resources\Constants.resx">
|
||||||
<Generator>ResXFileCodeGenerator</Generator>
|
<Generator>PublicResXFileCodeGenerator</Generator>
|
||||||
<LastGenOutput>Constants.Designer.cs</LastGenOutput>
|
<LastGenOutput>Constants.Designer.cs</LastGenOutput>
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
</EmbeddedResource>
|
||||||
|
<EmbeddedResource Include="Resources\Icons.resx">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
</EmbeddedResource>
|
</EmbeddedResource>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<Reference Include="AsyncCtpLibrary_Phone">
|
||||||
|
<HintPath>..\packages\BuiltToRoam.Core.Agent.1.0.1.5\lib\sl4-wp71\AsyncCtpLibrary_Phone.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="BuiltToRoam.Core.Agent">
|
||||||
|
<HintPath>..\packages\BuiltToRoam.Core.Agent.1.0.1.5\lib\sl4-wp71\BuiltToRoam.Core.Agent.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="BuiltToRoam.GeoWatcher">
|
||||||
|
<HintPath>..\packages\BuiltToRoam.GeoWatcher.1.0.1.5\lib\sl4-wp71\BuiltToRoam.GeoWatcher.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
<Reference Include="Microsoft.Phone.Controls, Version=8.0.0.0, Culture=neutral, PublicKeyToken=24eec0d8c86cda1e, processorArchitecture=MSIL" />
|
<Reference Include="Microsoft.Phone.Controls, Version=8.0.0.0, Culture=neutral, PublicKeyToken=24eec0d8c86cda1e, processorArchitecture=MSIL" />
|
||||||
<Reference Include="Microsoft.Phone.Controls.Toolkit">
|
<Reference Include="Microsoft.Phone.Controls.Toolkit">
|
||||||
<HintPath>..\packages\WPtoolkit.4.2012.10.30\lib\wp8\Microsoft.Phone.Controls.Toolkit.dll</HintPath>
|
<HintPath>..\packages\WPtoolkit.4.2012.10.30\lib\wp8\Microsoft.Phone.Controls.Toolkit.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
|
<Reference Include="Newtonsoft.Json">
|
||||||
|
<HintPath>..\packages\Newtonsoft.Json.4.5.11\lib\sl4-windowsphone71\Newtonsoft.Json.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="SharpZipLib.WindowsPhone7">
|
||||||
|
<HintPath>..\packages\SharpZipLib-WP7.0.86.0.518\lib\sl4-windowsphone71\SharpZipLib.WindowsPhone7.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup />
|
<ItemGroup />
|
||||||
<Import Project="$(MSBuildExtensionsPath)\Microsoft\$(TargetFrameworkIdentifier)\$(TargetFrameworkVersion)\Microsoft.$(TargetFrameworkIdentifier).$(TargetFrameworkVersion).Overrides.targets" />
|
<Import Project="$(MSBuildExtensionsPath)\Microsoft\$(TargetFrameworkIdentifier)\$(TargetFrameworkVersion)\Microsoft.$(TargetFrameworkIdentifier).$(TargetFrameworkVersion).Overrides.targets" />
|
||||||
|
|||||||
33
CampusAppWP8/CampusAppWP8/Const.cs
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="Const.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>08.07.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8
|
||||||
|
{
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Access to Constants.rex
|
||||||
|
/// </summary>
|
||||||
|
public class Const
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Resource object.
|
||||||
|
/// </summary>
|
||||||
|
private static Constants constantResources = new Constants();
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the resource object.
|
||||||
|
/// </summary>
|
||||||
|
public Constants Constants
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return constantResources;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,103 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="DepartmentFavoriteFeed.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>fiedlchr</author>
|
||||||
|
// <sience>01.07.2013</sience>
|
||||||
|
//----------------------------------------------------------------------using System;
|
||||||
|
namespace CampusAppWP8.Feed.Departments
|
||||||
|
{
|
||||||
|
using System.IO;
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.Departments;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Feed object to handle favorite department feeds.
|
||||||
|
/// </summary>
|
||||||
|
public class DepartmentFavoriteFeed : XmlModel<DepartmentModel>
|
||||||
|
{
|
||||||
|
#region Constructor
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="DepartmentFavoriteFeed" /> class.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="autoLoad">automatic loading of the data</param>
|
||||||
|
public DepartmentFavoriteFeed(bool autoLoad = true)
|
||||||
|
: base(ModelType.File, Constants.FileDepartment_Favorite_Name, string.Empty)
|
||||||
|
{
|
||||||
|
this.isFileUpToDateOnLoad += new IsFileUpToDate(this.CheckIsFileUpToDateOnLoad);
|
||||||
|
this.isFileUpToDateOnSave += new IsFileUpToDate(this.CheckIsFileUpToDateOnSave);
|
||||||
|
|
||||||
|
if (autoLoad == true)
|
||||||
|
{
|
||||||
|
this.LoadData();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Constructor
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Method
|
||||||
|
|
||||||
|
#region Protected
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method implement CheckIsModelUpToDate()-Method <see cref="Pages"/>.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsModelUpToDate(DepartmentModel model)
|
||||||
|
{
|
||||||
|
bool retValue = true;
|
||||||
|
|
||||||
|
if ((model == null)
|
||||||
|
|| (model.Faculties == null)
|
||||||
|
|| (model.Faculties.Count != 1))
|
||||||
|
{
|
||||||
|
retValue = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method implement CheckIsFileUpToDate()-Method <see cref="Pages"/>.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <param name="info">file info object</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDateOnLoad(DepartmentModel model, FileInfo info)
|
||||||
|
{
|
||||||
|
bool retValue = false;
|
||||||
|
|
||||||
|
if (this.Model == null)
|
||||||
|
{
|
||||||
|
retValue = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method implement CheckIsFileUpToDate()-Method <see cref="Pages"/>.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <param name="info">file info object</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDateOnSave(DepartmentModel model, FileInfo info)
|
||||||
|
{
|
||||||
|
bool retValue = false;
|
||||||
|
|
||||||
|
retValue = (model.HasChanged() == false) ? true : false;
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Protected
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
// Method
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,37 +1,116 @@
|
|||||||
using CampusAppWP8.Model.Departments;
|
//-----------------------------------------------------------------------
|
||||||
using CampusAppWP8.Utility;
|
// <copyright file="DepartmentFeed.cs" company="BTU/IIT">
|
||||||
using System;
|
// Company copyright tag.
|
||||||
using System.Collections.Generic;
|
// </copyright>
|
||||||
using System.Linq;
|
// <author>fiedlchr</author>
|
||||||
using System.Text;
|
// <sience>24.06.2013</sience>
|
||||||
using System.Threading.Tasks;
|
//----------------------------------------------------------------------
|
||||||
|
|
||||||
namespace CampusAppWP8.Feed.Departments
|
namespace CampusAppWP8.Feed.Departments
|
||||||
{
|
{
|
||||||
class DepartmentFeed : XmlFeed<DepartmentViewModel>
|
using System.IO;
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.Departments;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
using CampusAppWP8.Utility;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Feed class for the department information.
|
||||||
|
/// </summary>
|
||||||
|
public class DepartmentFeed : XmlModel<DepartmentModel>
|
||||||
{
|
{
|
||||||
public DepartmentFeed() : base(URLList.DepartmentFeedURL, "DepartmentFeed.xml")
|
#region Constructor
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
public System.Collections.ObjectModel.ObservableCollection<FacultyModel> _faculties { get; set; }
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Method implement CheckIsModelUpToDate()-Method <see cref="Feed"/>
|
/// Initializes a new instance of the <see cref="DepartmentFeed" /> class.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
/// <param name="autoLoad">automatic loading of the data</param>
|
||||||
|
public DepartmentFeed(bool autoLoad = true)
|
||||||
|
: base(ModelType.FileAndFeed, Constants.FileDepartment_Name, Constants.UrlDepartment_Addr)
|
||||||
|
{
|
||||||
|
this.isFileUpToDateOnLoad += new IsFileUpToDate(this.CheckIsFileUpToDateOnLoad);
|
||||||
|
this.isFileUpToDateOnSave += new IsFileUpToDate(this.CheckIsFileUpToDateOnSave);
|
||||||
|
this.isModelUpToDateOnLoad += new IsModelUpToDate(this.CheckIsModelUpToDate);
|
||||||
|
|
||||||
|
if (autoLoad == true)
|
||||||
|
{
|
||||||
|
this.LoadData();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Constructor
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Method
|
||||||
|
|
||||||
|
#region Protected
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method implement CheckIsModelUpToDate()-Method <see cref="Pages"/>.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
||||||
protected override bool CheckIsModelUpToDate()
|
private bool CheckIsModelUpToDate(DepartmentModel model)
|
||||||
{
|
{
|
||||||
return false;
|
bool retValue = true;
|
||||||
|
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
retValue = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
retValue = Utilities.DayDifference(Utilities.DifferenceType.Less, model.CreateTime, 7.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Method implement CheckIsFileUpToDate()-Method <see cref="Feed"/>
|
/// Method implement CheckIsFileUpToDate()-Method <see cref="Pages"/>.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <param name="info">file info object</param>
|
||||||
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
protected override bool CheckIsFileUpToDate()
|
private bool CheckIsFileUpToDateOnLoad(DepartmentModel model, FileInfo info)
|
||||||
{
|
{
|
||||||
return false;
|
bool retValue = true;
|
||||||
|
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
// at loading
|
||||||
|
if (info.Exists == true)
|
||||||
|
{
|
||||||
|
retValue = Utilities.DayDifference(Utilities.DifferenceType.Less, info.LastWriteTime, 7.0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method implement CheckIsFileUpToDate()-Method <see cref="Pages"/>.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <param name="info">file info object</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDateOnSave(DepartmentModel model, FileInfo info)
|
||||||
|
{
|
||||||
|
bool retValue = true;
|
||||||
|
|
||||||
|
// at saving
|
||||||
|
if ((info.Exists == false)
|
||||||
|
|| (info.Length == 0))
|
||||||
|
{
|
||||||
|
retValue = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Protedted
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
// Method
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,41 +1,100 @@
|
|||||||
using System;
|
//-----------------------------------------------------------------------
|
||||||
using System.Collections.Generic;
|
// <copyright file="EventFeed.cs" company="BTU/IIT">
|
||||||
using System.Linq;
|
// Company copyright tag.
|
||||||
using System.Text;
|
// </copyright>
|
||||||
using System.Threading.Tasks;
|
// <author>fiedlchr</author>
|
||||||
|
// <sience>24.06.2013</sience>
|
||||||
using CampusAppWP8.Model.events_news;
|
//----------------------------------------------------------------------
|
||||||
using CampusAppWP8.Utility;
|
|
||||||
|
|
||||||
namespace CampusAppWP8.Feed.Events
|
namespace CampusAppWP8.Feed.Events
|
||||||
{
|
{
|
||||||
|
using System.IO;
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.RSS;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
using CampusAppWP8.Utility;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Event Feed.
|
/// Event Feed.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class EventFeed : XmlFeed<RSSViewModel>
|
public class EventFeed : XmlModel<RSSViewModel>
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Default constructor.
|
/// Initializes a new instance of the <see cref="EventFeed" /> class.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public EventFeed() : base(URLList.EventsFeedURL, "EventFeed.xml")
|
/// <param name="autoLoad">automatic loading of the data</param>
|
||||||
|
public EventFeed(bool autoLoad = true)
|
||||||
|
: base(ModelType.FileAndFeed, Constants.FileEvents_Name, Constants.UrlEvents_Addr)
|
||||||
{
|
{
|
||||||
}
|
this.isFileUpToDateOnLoad += new IsFileUpToDate(this.CheckIsFileUpToDateOnLoad);
|
||||||
/// <summary>
|
this.isFileUpToDateOnSave += new IsFileUpToDate(this.CheckIsFileUpToDateOnSave);
|
||||||
/// Method implement CheckIsModelUpToDate()-Method <see cref="Feed"/>
|
this.isModelUpToDateOnLoad += new IsModelUpToDate(this.CheckIsModelUpToDate);
|
||||||
/// </summary>
|
|
||||||
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
if (autoLoad == true)
|
||||||
protected override bool CheckIsModelUpToDate()
|
{
|
||||||
{
|
this.LoadData();
|
||||||
return false;
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Method implement CheckIsFileUpToDate()-Method <see cref="Feed"/>
|
/// Method implement CheckIsModelUpToDate()-Method <see cref="Pages"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
/// <param name="model">model object</param>
|
||||||
protected override bool CheckIsFileUpToDate()
|
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsModelUpToDate(RSSViewModel model)
|
||||||
{
|
{
|
||||||
return true;
|
bool retValue = true;
|
||||||
|
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
retValue = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
retValue = Utilities.DayDifference(Utilities.DifferenceType.Less, model.CreateTime, 1.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method implement CheckIsFileUpToDate()-Method <see cref="Pages"/>
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <param name="info">file info object</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDateOnLoad(RSSViewModel model, FileInfo info)
|
||||||
|
{
|
||||||
|
bool retValue = true;
|
||||||
|
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
// at loading
|
||||||
|
if (info.Exists == true)
|
||||||
|
{
|
||||||
|
retValue = Utilities.DayDifference(Utilities.DifferenceType.Less, info.LastWriteTime, 1.0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method implement CheckIsFileUpToDate()-Method <see cref="Pages"/>
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <param name="info">file info object</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDateOnSave(RSSViewModel model, FileInfo info)
|
||||||
|
{
|
||||||
|
bool retValue = true;
|
||||||
|
|
||||||
|
if ((info.Exists == false)
|
||||||
|
|| (info.Length == 0))
|
||||||
|
{
|
||||||
|
retValue = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
88
CampusAppWP8/CampusAppWP8/Feed/Link/ClubLinkFeed.cs
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="ClubLinkFeed.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>02.07.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.Feed.Link
|
||||||
|
{
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.Link;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
using CampusAppWP8.Utility;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// This Class is for ClubLinkFeeds
|
||||||
|
/// </summary>
|
||||||
|
public class ClubLinkFeed : XmlModel<LinkListModel>
|
||||||
|
{
|
||||||
|
#region Constructor
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="ClubLinkFeed" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public ClubLinkFeed()
|
||||||
|
: base(ModelType.FileAndFeed, Constants.FileLink_ClubLinks, Constants.UrlLink_ClubLinks)
|
||||||
|
{
|
||||||
|
this.isFileUpToDateOnLoad += new IsFileUpToDate(this.CheckIsFileUpToDate);
|
||||||
|
this.isModelUpToDateOnLoad += new IsModelUpToDate(this.CheckIsModelUpToDate);
|
||||||
|
this.isFileUpToDateOnSave += new IsFileUpToDate(this.CheckIsFileUpToDate);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Method
|
||||||
|
|
||||||
|
#region Private
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedModel is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsModelUpToDate(LinkListModel model)
|
||||||
|
{
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
DateTime lastModified = model.CreateTime;
|
||||||
|
return this.CheckIsUpToDate(lastModified);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedFile is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <param name="fileInfo">info about the file</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDate(LinkListModel model, FileInfo fileInfo)
|
||||||
|
{
|
||||||
|
if (fileInfo == null || !fileInfo.Exists)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
DateTime lastModified = fileInfo.LastWriteTime;
|
||||||
|
return this.CheckIsUpToDate(lastModified);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Check if the model or file is up-to-date.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="lastModified">Date of the last modification</param>
|
||||||
|
/// <returns>true, if is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsUpToDate(DateTime lastModified)
|
||||||
|
{
|
||||||
|
return Utilities.DayDifference(Utilities.DifferenceType.Less, lastModified, 7.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
88
CampusAppWP8/CampusAppWP8/Feed/Link/CommonLinkFeed.cs
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="CommonLinkFeed.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>02.07.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.Feed.Link
|
||||||
|
{
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.Link;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
using CampusAppWP8.Utility;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// This Class is for CommonLinkFeeds
|
||||||
|
/// </summary>
|
||||||
|
public class CommonLinkFeed : XmlModel<LinkListModel>
|
||||||
|
{
|
||||||
|
#region Constructor
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="CommonLinkFeed" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public CommonLinkFeed()
|
||||||
|
: base(ModelType.FileAndFeed, Constants.FileLink_CommonLinks, Constants.UrlLink_CommonLinks)
|
||||||
|
{
|
||||||
|
this.isFileUpToDateOnLoad += new IsFileUpToDate(this.CheckIsFileUpToDate);
|
||||||
|
this.isFileUpToDateOnSave += new IsFileUpToDate(this.CheckIsFileUpToDate);
|
||||||
|
this.isModelUpToDateOnLoad += new IsModelUpToDate(this.CheckIsModelUpToDate);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Method
|
||||||
|
|
||||||
|
#region Private
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedModel is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsModelUpToDate(LinkListModel model)
|
||||||
|
{
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
DateTime lastModified = model.CreateTime;
|
||||||
|
return this.CheckIsUpToDate(lastModified);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedFile is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <param name="fileInfo">info about the file</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDate(LinkListModel model, FileInfo fileInfo)
|
||||||
|
{
|
||||||
|
if (fileInfo == null || !fileInfo.Exists)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
DateTime lastModified = fileInfo.LastWriteTime;
|
||||||
|
return this.CheckIsUpToDate(lastModified);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Check if the model or file is up-to-date.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="lastModified">Date of the last modification</param>
|
||||||
|
/// <returns>true, if is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsUpToDate(DateTime lastModified)
|
||||||
|
{
|
||||||
|
return Utilities.DayDifference(Utilities.DifferenceType.Less, lastModified, 7.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -5,17 +5,18 @@
|
|||||||
// <author>stubbfel</author>
|
// <author>stubbfel</author>
|
||||||
// <sience>03.05.2013</sience>
|
// <sience>03.05.2013</sience>
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
namespace CampusAppWP8.Pages.Mensa
|
namespace CampusAppWP8.Feed.Mensa
|
||||||
{
|
{
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.ObjectModel;
|
using System.IO;
|
||||||
|
using CampusAppWP8.Model;
|
||||||
using CampusAppWP8.Model.Mensa;
|
using CampusAppWP8.Model.Mensa;
|
||||||
using CampusAppWP8.Utility;
|
using CampusAppWP8.Resources;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// This Class is for MesaFeeds
|
/// This Class is for MensaFeeds
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class MensaFeed : XmlFeed<MenuWeekModel>
|
public class MensaFeed : XmlModel<MenuWeekModel>
|
||||||
{
|
{
|
||||||
#region Constructor
|
#region Constructor
|
||||||
|
|
||||||
@@ -23,40 +24,52 @@ namespace CampusAppWP8.Pages.Mensa
|
|||||||
/// Initializes a new instance of the <see cref="MensaFeed" /> class.
|
/// Initializes a new instance of the <see cref="MensaFeed" /> class.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public MensaFeed()
|
public MensaFeed()
|
||||||
: base(URLList.MensaFeedURL, FileList.MensaXmlFile)
|
: base(ModelType.FileAndFeed, Constants.FileMensa_Shedule, Constants.UrlMensa_Week)
|
||||||
{
|
{
|
||||||
|
this.isFileUpToDateOnLoad += new IsFileUpToDate(this.CheckIsFileUpToDate);
|
||||||
|
this.isModelUpToDateOnLoad += new IsModelUpToDate(this.CheckIsModelUpToDate);
|
||||||
|
this.isFileUpToDateOnSave += new IsFileUpToDate(this.CheckIsFileUpToDate);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Method
|
#region Method
|
||||||
|
|
||||||
#region Protected
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Method implement CheckIsModelUpToDate()-Method <see cref="Feed"/>
|
|
||||||
/// </summary>
|
|
||||||
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
|
||||||
protected override bool CheckIsModelUpToDate()
|
|
||||||
{
|
|
||||||
DateTime lastModified = this.Model.CreateTime;
|
|
||||||
return this.CheckIsUpToDate(lastModified);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Method implement CheckIsFileUpToDate()-Method <see cref="Feed"/>
|
|
||||||
/// </summary>
|
|
||||||
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
|
||||||
protected override bool CheckIsFileUpToDate()
|
|
||||||
{
|
|
||||||
DateTime lastModified = FileManager.GetFileInfo(FileName).LastWriteTime;
|
|
||||||
return this.CheckIsUpToDate(lastModified);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region Private
|
#region Private
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedModel is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsModelUpToDate(MenuWeekModel model)
|
||||||
|
{
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
DateTime lastModified = model.CreateTime;
|
||||||
|
return this.CheckIsUpToDate(lastModified);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedFile is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <param name="fileInfo">info about the file</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDate(MenuWeekModel model, FileInfo fileInfo)
|
||||||
|
{
|
||||||
|
if (fileInfo == null || !fileInfo.Exists)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
DateTime lastModified = fileInfo.LastWriteTime;
|
||||||
|
return this.CheckIsUpToDate(lastModified);
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Method check if the last modification was later as the NewMenuWeekDay
|
/// Method check if the last modification was later as the NewMenuWeekDay
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -1,42 +1,99 @@
|
|||||||
using System;
|
//-----------------------------------------------------------------------------
|
||||||
using System.Collections.Generic;
|
// <copyright file="NewsFeed.cs" company="BTU/IIT">
|
||||||
using System.Linq;
|
// Company copyright tag.
|
||||||
using System.Text;
|
// </copyright>
|
||||||
using System.Threading.Tasks;
|
// <author>fiedlchr</author>
|
||||||
|
// <sience>24.06.2013</sience>
|
||||||
using CampusAppWP8.Model.events_news;
|
//-----------------------------------------------------------------------------
|
||||||
using CampusAppWP8.Utility;
|
|
||||||
|
|
||||||
namespace CampusAppWP8.Feed.News
|
namespace CampusAppWP8.Feed.News
|
||||||
{
|
{
|
||||||
|
using System.IO;
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.RSS;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
using CampusAppWP8.Utility;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// News Feed.
|
/// News Feed.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class NewsFeed : XmlFeed<RSSViewModel>
|
public class NewsFeed : XmlModel<RSSViewModel>
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Default constructor.
|
/// Initializes a new instance of the <see cref="NewsFeed" /> class.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public NewsFeed() : base(URLList.NewsFeedURL, "NewsFeed.xml")
|
/// <param name="autoLoad">automatic loading of the data</param>
|
||||||
|
public NewsFeed(bool autoLoad = true)
|
||||||
|
: base(ModelType.FileAndFeed, Constants.FileNews_Name, Constants.UrlNews_Addr)
|
||||||
{
|
{
|
||||||
|
this.isFileUpToDateOnLoad += new IsFileUpToDate(this.CheckIsFileUpToDateOnLoad);
|
||||||
|
this.isFileUpToDateOnSave += new IsFileUpToDate(this.CheckIsFileUpToDateOnSave);
|
||||||
|
this.isModelUpToDateOnLoad += new IsModelUpToDate(this.CheckIsModelUpToDate);
|
||||||
|
|
||||||
|
if (autoLoad == true)
|
||||||
|
{
|
||||||
|
this.LoadData();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Method implement CheckIsModelUpToDate()-Method <see cref="Feed"/>
|
/// Method implement CheckIsModelUpToDate()-Method <see cref="Pages"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
||||||
protected override bool CheckIsModelUpToDate()
|
private bool CheckIsModelUpToDate(RSSViewModel model)
|
||||||
{
|
{
|
||||||
return false;
|
bool retValue = true;
|
||||||
|
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
retValue = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
retValue = Utilities.DayDifference(Utilities.DifferenceType.Less, model.CreateTime, 1.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Method implement CheckIsFileUpToDate()-Method <see cref="Feed"/>
|
/// Method implement CheckIsFileUpToDate()-Method <see cref="Pages"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <param name="info">info object of the file</param>
|
||||||
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
protected override bool CheckIsFileUpToDate()
|
private bool CheckIsFileUpToDateOnLoad(RSSViewModel model, FileInfo info)
|
||||||
{
|
{
|
||||||
return true;
|
bool retValue = true;
|
||||||
|
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
if (info.Exists == true)
|
||||||
|
{
|
||||||
|
retValue = Utilities.DayDifference(Utilities.DifferenceType.Less, info.LastWriteTime, 1.0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method implement CheckIsFileUpToDate()-Method <see cref="Pages"/>
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <param name="info">info object of the file</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDateOnSave(RSSViewModel model, FileInfo info)
|
||||||
|
{
|
||||||
|
bool retValue = true;
|
||||||
|
|
||||||
|
if ((info.Exists == false)
|
||||||
|
|| (info.Length == 0))
|
||||||
|
{
|
||||||
|
retValue = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
105
CampusAppWP8/CampusAppWP8/Feed/Openinghours/OpeninghoursFeed.cs
Normal file
@@ -0,0 +1,105 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="OpeninghoursFeed.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>fiedlchr</author>
|
||||||
|
// <sience>24.06.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.Feed.Openinghours
|
||||||
|
{
|
||||||
|
using System.IO;
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.Openinghours;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
using CampusAppWP8.Utility;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// This Class is for MesaFeeds
|
||||||
|
/// </summary>
|
||||||
|
public class OpeninghoursFeed : XmlModel<OpeninghoursModel>
|
||||||
|
{
|
||||||
|
#region Constructor
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="OpeninghoursFeed" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public OpeninghoursFeed()
|
||||||
|
: base(ModelType.FileAndFeed, Constants.FileOpeningHours_OpeningHours, Constants.UrlOpeningHours_OpeningHours)
|
||||||
|
{
|
||||||
|
this.isFileUpToDateOnLoad += new IsFileUpToDate(this.CheckIsFileUpToDateOnLoad);
|
||||||
|
this.isFileUpToDateOnSave += new IsFileUpToDate(this.CheckIsFileUpToDateOnSave);
|
||||||
|
this.isModelUpToDateOnLoad += new IsModelUpToDate(this.CheckIsModelUpToDate);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Method
|
||||||
|
|
||||||
|
#region Private
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedModel is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsModelUpToDate(OpeninghoursModel model)
|
||||||
|
{
|
||||||
|
bool retValue = true;
|
||||||
|
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
retValue = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
retValue = Utilities.DayDifference(Utilities.DifferenceType.Less, model.CreateTime, 7.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedFile is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <param name="info">info about the file</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDateOnLoad(OpeninghoursModel model, FileInfo info)
|
||||||
|
{
|
||||||
|
bool retValue = true;
|
||||||
|
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
if (info.Exists == true)
|
||||||
|
{
|
||||||
|
retValue = Utilities.DayDifference(Utilities.DifferenceType.Less, info.LastWriteTime, 7.0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedFile is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <param name="info">info about the file</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDateOnSave(OpeninghoursModel model, FileInfo info)
|
||||||
|
{
|
||||||
|
bool retValue = true;
|
||||||
|
|
||||||
|
if ((info.Exists == false)
|
||||||
|
|| (info.Length == 0))
|
||||||
|
{
|
||||||
|
retValue = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,88 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="StudentCouncilFeed.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>02.07.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.Feed.StudentCouncil
|
||||||
|
{
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.StudentCouncil;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
using CampusAppWP8.Utility;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// This Class is for StudentCouncilFeed
|
||||||
|
/// </summary>
|
||||||
|
public class StudentCouncilFeed : XmlModel<StudentCouncilListModel>
|
||||||
|
{
|
||||||
|
#region Constructor
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="StudentCouncilFeed" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public StudentCouncilFeed()
|
||||||
|
: base(ModelType.FileAndFeed, Constants.FileStudentCouncil_StudentCouncils, Constants.UrlStudentCouncil_StudentCouncils)
|
||||||
|
{
|
||||||
|
this.isFileUpToDateOnLoad += new IsFileUpToDate(this.CheckIsFileUpToDate);
|
||||||
|
this.isModelUpToDateOnLoad += new IsModelUpToDate(this.CheckIsModelUpToDate);
|
||||||
|
this.isFileUpToDateOnSave += new IsFileUpToDate(this.CheckIsFileUpToDate);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Method
|
||||||
|
|
||||||
|
#region Private
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedModel is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <returns>true, if model is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsModelUpToDate(StudentCouncilListModel model)
|
||||||
|
{
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
DateTime lastModified = model.CreateTime;
|
||||||
|
return this.CheckIsUpToDate(lastModified);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method check if the FeedFile is up-to-date
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">reference of the FeedModel</param>
|
||||||
|
/// <param name="fileInfo">info about the file</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDate(StudentCouncilListModel model, FileInfo fileInfo)
|
||||||
|
{
|
||||||
|
if (fileInfo == null || !fileInfo.Exists)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
DateTime lastModified = fileInfo.LastWriteTime;
|
||||||
|
return this.CheckIsUpToDate(lastModified);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Check if the model or file is up-to-date.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="lastModified">Date of the last modification</param>
|
||||||
|
/// <returns>true, if is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsUpToDate(DateTime lastModified)
|
||||||
|
{
|
||||||
|
return Utilities.DayDifference(Utilities.DifferenceType.Less, lastModified, 7.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
67
CampusAppWP8/CampusAppWP8/File/Setting/UserProfilFile.cs
Normal file
@@ -0,0 +1,67 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="UserProfilFile.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>23.07.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.File.Setting
|
||||||
|
{
|
||||||
|
using System.IO;
|
||||||
|
using CampusAppWP8.Model;
|
||||||
|
using CampusAppWP8.Model.Setting;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Class for handle the user-profile-file
|
||||||
|
/// </summary>
|
||||||
|
public class UserProfilFile : XmlModel<UserProfilModel>
|
||||||
|
{
|
||||||
|
#region Constructor
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="UserProfilFile" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public UserProfilFile()
|
||||||
|
: base(ModelType.File, Constants.FileProfil_User)
|
||||||
|
{
|
||||||
|
this.isFileUpToDateOnLoad += new IsFileUpToDate(this.CheckIsFileUpToDateOnLoad);
|
||||||
|
this.isFileUpToDateOnSave += new IsFileUpToDate(this.CheckIsFileUpToDateOnSave);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Constructor
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method implement CheckIsFileUpToDate()-Method <see cref="Pages"/>.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <param name="info">file info object</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDateOnLoad(UserProfilModel model, FileInfo info)
|
||||||
|
{
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method implement CheckIsFileUpToDate()-Method <see cref="Pages"/>.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="model">model object</param>
|
||||||
|
/// <param name="info">file info object</param>
|
||||||
|
/// <returns>true, if file is up-to-date, otherwise false</returns>
|
||||||
|
private bool CheckIsFileUpToDateOnSave(UserProfilModel model, FileInfo info)
|
||||||
|
{
|
||||||
|
if (model != null && !model.HasChanged())
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
177
CampusAppWP8/CampusAppWP8/Model/Campusmap/MapModel.cs
Normal file
@@ -0,0 +1,177 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="MapModel.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>24.06.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.Model.Campusmap
|
||||||
|
{
|
||||||
|
using System;
|
||||||
|
using System.Windows;
|
||||||
|
using System.Windows.Controls;
|
||||||
|
using System.Windows.Media.Imaging;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// This Class manage the properties of a Map
|
||||||
|
/// </summary>
|
||||||
|
public class MapModel
|
||||||
|
{
|
||||||
|
#region Constructors
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="MapModel" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public MapModel()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Property
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ImageSource of the map
|
||||||
|
/// </summary>
|
||||||
|
public string ImageSource { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ImageWidth of the map
|
||||||
|
/// </summary>
|
||||||
|
public double ImageWidth { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ImageHeight of the map
|
||||||
|
/// </summary>
|
||||||
|
public double ImageHeight { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ImageOffsetX of the map
|
||||||
|
/// </summary>
|
||||||
|
public double MapImageOffsetX { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ImageOffsetY of the map
|
||||||
|
/// </summary>
|
||||||
|
public double MapImageOffsetY { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the GeoOffsetX of the map
|
||||||
|
/// </summary>
|
||||||
|
public double GeoOffsetX { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the GeoOffsetY of the map
|
||||||
|
/// </summary>
|
||||||
|
public double GeoOffsetY { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the Scale (to pixel) of the map
|
||||||
|
/// </summary>
|
||||||
|
public double Scale { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the reference point
|
||||||
|
/// </summary>
|
||||||
|
public Point RefPoint { get; set; }
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Methods
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method calculate the coordinates of ScrollToOffsets point
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="point">input point</param>
|
||||||
|
/// <returns>point (in pixel)</returns>
|
||||||
|
public Point GetScrollPoint(Point point)
|
||||||
|
{
|
||||||
|
return this.GetScrollPoint(point.X, point.Y);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method calculate the coordinates of ScrollToOffsets point
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>the input-point will be shown in the center</remarks>
|
||||||
|
/// <param name="x">x - coordinate</param>
|
||||||
|
/// <param name="y">y - coordinate</param>
|
||||||
|
/// <returns>point (in pixel)</returns>
|
||||||
|
public Point GetScrollPoint(double x, double y)
|
||||||
|
{
|
||||||
|
x = this.RefPoint.X + this.MapImageOffsetX + x;
|
||||||
|
y = this.RefPoint.Y + this.MapImageOffsetY - y;
|
||||||
|
return new Point(x, y);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method create in image, which can show at a certain position
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="x">the x- coordinate</param>
|
||||||
|
/// <param name="y">the y-coordinate</param>
|
||||||
|
/// <returns>image of the pin</returns>
|
||||||
|
public Image AddPin(double x, double y)
|
||||||
|
{
|
||||||
|
Point position = new Point(x, y);
|
||||||
|
return this.AddPin(position);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method create in image, which can show at a certain position depend of the <see cref="RefPoint" />
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="x">the x-coordinate</param>
|
||||||
|
/// <param name="y">the y-coordinate</param>
|
||||||
|
/// <returns>image of the pin</returns>
|
||||||
|
public Image AddPinFromRefPoint(double x, double y)
|
||||||
|
{
|
||||||
|
Point position = new Point(this.RefPoint.X + x, this.RefPoint.Y - y);
|
||||||
|
return this.AddPin(position);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method create in image, which can show at a certain position depend of the <see cref="RefPoint" />
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="position">input point</param>
|
||||||
|
/// <returns>image of the pin</returns>
|
||||||
|
public Image AddPinFromRefPoint(Point position)
|
||||||
|
{
|
||||||
|
return this.AddPinFromRefPoint(position.X, position.Y);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method create in image, which can show at a certain position
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="position">input point</param>
|
||||||
|
/// <returns>image of the pin</returns>
|
||||||
|
public Image AddPin(Point position)
|
||||||
|
{
|
||||||
|
MapPinModel pin = new MapPinModel() { Position = position };
|
||||||
|
Image pinImg = new Image() { Source = new BitmapImage(new Uri(pin.ImageSource, UriKind.Relative)), Width = pin.ImageWidth };
|
||||||
|
Canvas.SetTop(pinImg, pin.Position.Y);
|
||||||
|
Canvas.SetLeft(pinImg, pin.Position.X);
|
||||||
|
return pinImg;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert a coordinates to coordinates which address pixels
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="x">the x-coordinate</param>
|
||||||
|
/// <param name="y">the y-coordinate</param>
|
||||||
|
/// <returns>Point in pixel-size</returns>
|
||||||
|
public Point ConverToPixelPoint(double x, double y)
|
||||||
|
{
|
||||||
|
return new Point { X = this.Scale * x, Y = this.Scale * y };
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert a coordinates to coordinates which address pixels
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="point">not scaled point</param>
|
||||||
|
/// <returns>Point in pixel-size</returns>
|
||||||
|
public Point ConverToPixelPoint(Point point)
|
||||||
|
{
|
||||||
|
return this.ConverToPixelPoint(point.X, point.Y);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
106
CampusAppWP8/CampusAppWP8/Model/Campusmap/MapPinModel.cs
Normal file
@@ -0,0 +1,106 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="MapPinModel.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>24.06.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.Model.Campusmap
|
||||||
|
{
|
||||||
|
using System.Windows;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// This Class manage the properties of a MapPin
|
||||||
|
/// </summary>
|
||||||
|
public class MapPinModel
|
||||||
|
{
|
||||||
|
#region Member
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Variable of the actual position of the pin
|
||||||
|
/// </summary>
|
||||||
|
private Point position;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
#region Constructor
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="MapPinModel" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public MapPinModel()
|
||||||
|
{
|
||||||
|
this.ImageSource = "/Assets/icons/search_159_light.png";
|
||||||
|
this.ImageWidth = 60;
|
||||||
|
this.ImageHeight = 60;
|
||||||
|
this.PinImageOffsetX = -24;
|
||||||
|
this.PinImageOffsetY = -24;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Property
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ImageSource of the pin
|
||||||
|
/// </summary>
|
||||||
|
public string ImageSource { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ImageWidth of the pin
|
||||||
|
/// </summary>
|
||||||
|
public double ImageWidth { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ImageHeight of the pin
|
||||||
|
/// </summary>
|
||||||
|
public double ImageHeight { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ImageOffsetX of the pin
|
||||||
|
/// </summary>
|
||||||
|
public double PinImageOffsetX { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ImageOffsetY of the pin
|
||||||
|
/// </summary>
|
||||||
|
public double PinImageOffsetY { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets position of the pin
|
||||||
|
/// </summary>
|
||||||
|
public Point Position
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.position;
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
// null assert
|
||||||
|
if (value == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.position == null)
|
||||||
|
{
|
||||||
|
this.position = value;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// check the x-value
|
||||||
|
if (value.X + this.PinImageOffsetX != this.position.X)
|
||||||
|
{
|
||||||
|
this.position.X = value.X + this.PinImageOffsetX;
|
||||||
|
}
|
||||||
|
|
||||||
|
// check the y-value
|
||||||
|
if (value.Y + this.PinImageOffsetY != this.position.Y)
|
||||||
|
{
|
||||||
|
this.position.Y = value.Y + this.PinImageOffsetY;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,88 +1,126 @@
|
|||||||
using System;
|
//-----------------------------------------------------------------------
|
||||||
using System.Collections.Generic;
|
// <copyright file="ChairModel.cs" company="BTU/IIT">
|
||||||
using System.Linq;
|
// Company copyright tag.
|
||||||
using System.Text;
|
// </copyright>
|
||||||
using System.Xml.Serialization;
|
// <author>fiedlchr</author>
|
||||||
|
// <sience>24.06.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
namespace CampusAppWP8.Model.Departments
|
namespace CampusAppWP8.Model.Departments
|
||||||
{
|
{
|
||||||
|
using System.Globalization;
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Class to hold information about a professorship chair.
|
/// Class to hold information about a professorship chair.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class ChairModel : BaseModel
|
public class ChairModel
|
||||||
{
|
{
|
||||||
private string name_de; // german name of the chair
|
/// <summary>
|
||||||
private string url; // link-url to the chair homepage
|
/// German name of the chair.
|
||||||
private string name_en; // english name of the chair
|
/// </summary>
|
||||||
|
private string nameDE = string.Empty;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Default Constructor. Set every class variable to default value.
|
/// Link to the chair page.
|
||||||
|
/// </summary>
|
||||||
|
private string url = string.Empty;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// English name of the chair.
|
||||||
|
/// </summary>
|
||||||
|
private string nameEN = string.Empty;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="ChairModel" /> class.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public ChairModel()
|
public ChairModel()
|
||||||
{
|
{
|
||||||
this.name_de = String.Empty;
|
|
||||||
this.name_en = String.Empty;
|
|
||||||
this.url = String.Empty;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor. Set the german and english name.
|
/// Initializes a new instance of the <see cref="ChairModel" /> class.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="name">Name of the professorship chair.</param>
|
/// <param name="name">name of the chair</param>
|
||||||
public ChairModel(string name)
|
public ChairModel(string name)
|
||||||
{
|
{
|
||||||
this.name_de = name;
|
this.nameDE = name;
|
||||||
this.name_en = name;
|
this.nameEN = name;
|
||||||
this.url = String.Empty;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Set or return the german name of the chair.
|
/// Gets or sets the german name of the chair.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[XmlAttribute("name_de")]
|
[XmlAttribute("name_de")]
|
||||||
public string Name_DE
|
public string NameDE
|
||||||
{
|
{
|
||||||
get { return this.name_de; }
|
get
|
||||||
|
{
|
||||||
|
return this.nameDE;
|
||||||
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value != this.name_de)
|
if (value != this.nameDE)
|
||||||
{
|
{
|
||||||
this.name_de = value;
|
this.nameDE = value;
|
||||||
NotifyPropertyChanged("chair");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Set or return the english name of the chair.
|
/// Gets or sets the english name of the chair.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[XmlAttribute("name_en")]
|
[XmlAttribute("name_en")]
|
||||||
public string Name_EN
|
public string NameEN
|
||||||
{
|
{
|
||||||
get { return this.name_en; }
|
get
|
||||||
|
{
|
||||||
|
return this.nameEN;
|
||||||
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value != this.name_en)
|
if (value != this.nameEN)
|
||||||
{
|
{
|
||||||
this.name_en = value;
|
this.nameEN = value;
|
||||||
NotifyPropertyChanged("chair");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Set or return the url of the chair homepage.
|
/// Gets or sets the url of the chair homepage.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[XmlAttribute("url")]
|
[XmlAttribute("url")]
|
||||||
public string Url
|
public string Url
|
||||||
{
|
{
|
||||||
get { return this.url; }
|
get
|
||||||
|
{
|
||||||
|
return this.url;
|
||||||
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value != this.url)
|
if (value != this.url)
|
||||||
{
|
{
|
||||||
this.url = value;
|
this.url = value;
|
||||||
NotifyPropertyChanged("chair");
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the localized name of the chair.
|
||||||
|
/// </summary>
|
||||||
|
public string Name
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (CultureInfo.CurrentUICulture.Name.StartsWith("de"))
|
||||||
|
{
|
||||||
|
return this.NameDE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return this.NameEN;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,86 +1,91 @@
|
|||||||
using System;
|
//-----------------------------------------------------------------------
|
||||||
using System.Collections.Generic;
|
// <copyright file="DepartmentModel.cs" company="BTU/IIT">
|
||||||
using System.Collections.ObjectModel;
|
// Company copyright tag.
|
||||||
using System.Linq;
|
// </copyright>
|
||||||
using System.Text;
|
// <author>fiedlchr</author>
|
||||||
using System.Windows;
|
// <sience>24.06.2013</sience>
|
||||||
using System.Xml.Serialization;
|
//----------------------------------------------------------------------
|
||||||
|
|
||||||
namespace CampusAppWP8.Model.Departments
|
namespace CampusAppWP8.Model.Departments
|
||||||
{
|
{
|
||||||
public class DepartmentModel : BaseModel
|
using System;
|
||||||
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// View model for department page.
|
||||||
|
/// </summary>
|
||||||
|
[XmlRoot("root")]
|
||||||
|
public class DepartmentModel
|
||||||
{
|
{
|
||||||
[XmlElement("chair")]
|
/// <summary>
|
||||||
public ObservableCollection<ChairModel> _chairs { get; set; }
|
/// Object to store the time when the instance was created.
|
||||||
|
/// </summary>
|
||||||
|
private DateTime createTime;
|
||||||
|
|
||||||
private string _name = "d_mod";
|
/// <summary>
|
||||||
private Visibility visible;
|
/// List of faculties.
|
||||||
|
/// </summary>
|
||||||
|
private ObservableCollection<FacultyModel> faculties;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="DepartmentModel" /> class.
|
||||||
|
/// </summary>
|
||||||
public DepartmentModel()
|
public DepartmentModel()
|
||||||
{
|
{
|
||||||
this.visible = Visibility.Collapsed;
|
this.Faculties = new ObservableCollection<FacultyModel>();
|
||||||
this.Chairs = new ObservableCollection<ChairModel>();
|
this.createTime = DateTime.Now;
|
||||||
//this.LoadData();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public DepartmentModel(string name)
|
/// <summary>
|
||||||
{
|
/// Gets or sets the faculty list.
|
||||||
this.visible = Visibility.Collapsed;
|
/// </summary>
|
||||||
_name = name;
|
[XmlArray("professorships")]
|
||||||
this.Chairs = new ObservableCollection<ChairModel>();
|
[XmlArrayItem("faculty")]
|
||||||
//this.LoadData();
|
public ObservableCollection<FacultyModel> Faculties
|
||||||
}
|
|
||||||
|
|
||||||
public void LoadData()
|
|
||||||
{
|
|
||||||
this.Chairs.Add(new ChairModel("LS 1"));
|
|
||||||
this.Chairs.Add(new ChairModel("LS 2"));
|
|
||||||
this.Chairs.Add(new ChairModel("LS 3"));
|
|
||||||
this.Chairs.Add(new ChairModel("LS 4"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public ObservableCollection<ChairModel> Chairs
|
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
return _chairs;
|
return this.faculties;
|
||||||
}
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value != _chairs)
|
if (value != this.faculties)
|
||||||
{
|
{
|
||||||
_chairs = value;
|
this.faculties = value;
|
||||||
NotifyPropertyChanged("department");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public string Name
|
/// <summary>
|
||||||
|
/// Gets the creation time.
|
||||||
|
/// </summary>
|
||||||
|
public DateTime CreateTime
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
return _name;
|
return this.createTime;
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
if (value != _name)
|
|
||||||
{
|
|
||||||
_name = value;
|
|
||||||
NotifyPropertyChanged("chair");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Visibility Visible
|
/// <summary>
|
||||||
|
/// Check if the content of the faculty lists hast changed since the
|
||||||
|
/// last call of this function.
|
||||||
|
/// </summary>
|
||||||
|
/// <returns>true, if changes happen since last request, otherwise false</returns>
|
||||||
|
public bool HasChanged()
|
||||||
{
|
{
|
||||||
get { return this.visible; }
|
bool retValue = false;
|
||||||
set
|
|
||||||
|
foreach (FacultyModel temp in this.Faculties)
|
||||||
{
|
{
|
||||||
if (value != this.visible)
|
if ((temp.HasChanged() == true) && (retValue == false))
|
||||||
{
|
{
|
||||||
this.visible = value;
|
retValue = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,39 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Collections.ObjectModel;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Text;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using System.Xml.Serialization;
|
|
||||||
|
|
||||||
namespace CampusAppWP8.Model.Departments
|
|
||||||
{
|
|
||||||
[XmlRoot("root")]
|
|
||||||
public class DepartmentViewModel : BaseViewModel
|
|
||||||
{
|
|
||||||
[XmlArray("professorships")]
|
|
||||||
[XmlArrayItem("faculty")]
|
|
||||||
public ObservableCollection<FacultyModel> _faculties { get; set; }
|
|
||||||
|
|
||||||
public DepartmentViewModel()
|
|
||||||
{
|
|
||||||
this.Faculties = new ObservableCollection<FacultyModel>();
|
|
||||||
}
|
|
||||||
|
|
||||||
public ObservableCollection<FacultyModel> Faculties
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return _faculties;
|
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
if (value != _faculties)
|
|
||||||
{
|
|
||||||
_faculties = value;
|
|
||||||
NotifyPropertyChanged("foodDays");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,62 +1,238 @@
|
|||||||
using System;
|
//-----------------------------------------------------------------------
|
||||||
using System.Collections.Generic;
|
// <copyright file="FacultyModel.cs" company="BTU/IIT">
|
||||||
using System.Collections.ObjectModel;
|
// Company copyright tag.
|
||||||
using System.Linq;
|
// </copyright>
|
||||||
using System.Text;
|
// <author>fiedlchr</author>
|
||||||
using System.Xml.Serialization;
|
// <sience>24.06.2013</sience>
|
||||||
using CampusAppWP8.Resources;
|
//----------------------------------------------------------------------
|
||||||
|
|
||||||
namespace CampusAppWP8.Model.Departments
|
namespace CampusAppWP8.Model.Departments
|
||||||
{
|
{
|
||||||
public class FacultyModel : BaseModel
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for holding the faculty information.
|
||||||
|
/// </summary>
|
||||||
|
public class FacultyModel
|
||||||
{
|
{
|
||||||
[XmlElement("chair")]
|
/// <summary>
|
||||||
public ObservableCollection<ChairModel> chairs { get; set; }
|
/// Object to hold the information of the chair containing to this
|
||||||
//public ObservableCollection<DepartmentModel> _faculties { get; set; }
|
/// faculty.
|
||||||
|
/// </summary>
|
||||||
|
private ObservableCollection<ChairModel> chairs;
|
||||||
|
|
||||||
private string name = "t_fak";
|
/// <summary>
|
||||||
|
/// Name of the faculty.
|
||||||
|
/// </summary>
|
||||||
|
private string name = string.Empty;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// For checking of change.
|
||||||
|
/// </summary>
|
||||||
|
private bool hasChanged = false;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="FacultyModel" /> class.
|
||||||
|
/// </summary>
|
||||||
public FacultyModel()
|
public FacultyModel()
|
||||||
{
|
{
|
||||||
//this.Faculties = new ObservableCollection<DepartmentModel>();
|
|
||||||
this.chairs = new ObservableCollection<ChairModel>();
|
this.chairs = new ObservableCollection<ChairModel>();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="FacultyModel" /> class.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="name">name of the faculty</param>
|
||||||
public FacultyModel(string name)
|
public FacultyModel(string name)
|
||||||
{
|
{
|
||||||
this.name = name;
|
this.name = name;
|
||||||
//this.Faculties = new ObservableCollection<DepartmentModel>();
|
|
||||||
this.chairs = new ObservableCollection<ChairModel>();
|
this.chairs = new ObservableCollection<ChairModel>();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the list of the chairs containing to this faculty.
|
||||||
|
/// </summary>
|
||||||
|
[XmlElement("chair")]
|
||||||
public ObservableCollection<ChairModel> Chairs
|
public ObservableCollection<ChairModel> Chairs
|
||||||
{
|
{
|
||||||
get { return this.chairs; }
|
get
|
||||||
|
{
|
||||||
|
return this.chairs;
|
||||||
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value != this.chairs)
|
if (value != this.chairs)
|
||||||
{
|
{
|
||||||
this.chairs = value;
|
this.chairs = value;
|
||||||
NotifyPropertyChanged("faculty");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[XmlAttribute("id")]
|
/// <summary>
|
||||||
|
/// Gets the name of the faculty.
|
||||||
|
/// </summary>
|
||||||
public string Name
|
public string Name
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
return AppResources.Faculty + " " + this.name;
|
return AppResources.Faculty + " " + this.name;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the id of the faculty.
|
||||||
|
/// </summary>
|
||||||
|
[XmlAttribute("id")]
|
||||||
|
public string Id
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.name;
|
||||||
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value != this.name)
|
this.name = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Remove a chair model from the lost.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="chairName">name of the chair</param>
|
||||||
|
/// <returns>true, if succeeded</returns>
|
||||||
|
public bool RemoveChair(string chairName)
|
||||||
|
{
|
||||||
|
bool retValue = false;
|
||||||
|
|
||||||
|
ChairModel tempChair = null;
|
||||||
|
|
||||||
|
foreach (ChairModel temp in this.Chairs)
|
||||||
|
{
|
||||||
|
if (temp.Name.Equals(chairName) == true)
|
||||||
{
|
{
|
||||||
this.name = value;
|
tempChair = temp;
|
||||||
NotifyPropertyChanged("faculty");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (tempChair != null)
|
||||||
|
{
|
||||||
|
retValue = this.Chairs.Remove(tempChair);
|
||||||
|
this.hasChanged = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Add a chair to the list, if it does not already exist.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="chairModel">chair model to add</param>
|
||||||
|
/// <returns>true, is succeeded</returns>
|
||||||
|
public bool AddChair(ChairModel chairModel)
|
||||||
|
{
|
||||||
|
bool retValue = false;
|
||||||
|
|
||||||
|
if ((chairModel != null)
|
||||||
|
&& (this.Chairs.Contains(chairModel) == false))
|
||||||
|
{
|
||||||
|
bool isIn = false;
|
||||||
|
|
||||||
|
foreach (ChairModel temp in this.Chairs)
|
||||||
|
{
|
||||||
|
if ((temp.NameDE.Equals(chairModel.NameDE) == true)
|
||||||
|
|| (temp.NameEN.Equals(chairModel.NameEN) == true))
|
||||||
|
{
|
||||||
|
isIn = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isIn == false)
|
||||||
|
{
|
||||||
|
this.Chairs.Add(chairModel);
|
||||||
|
this.hasChanged = true;
|
||||||
|
retValue = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Create a chair model and add it to the list, if it does not already
|
||||||
|
/// exist.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="nameDE">german name of the chair</param>
|
||||||
|
/// <param name="nameEN">english name of the chair</param>
|
||||||
|
/// <param name="url">url of the chair home page</param>
|
||||||
|
/// <returns>true, if succeeded</returns>
|
||||||
|
public bool AddChair(string nameDE, string nameEN, string url)
|
||||||
|
{
|
||||||
|
bool retValue = false;
|
||||||
|
|
||||||
|
bool isIn = false;
|
||||||
|
|
||||||
|
foreach (ChairModel temp in this.Chairs)
|
||||||
|
{
|
||||||
|
if ((temp.NameDE.Equals(nameDE) == true)
|
||||||
|
|| (temp.NameEN.Equals(nameEN) == true))
|
||||||
|
{
|
||||||
|
isIn = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isIn == false)
|
||||||
|
{
|
||||||
|
ChairModel newModel = new ChairModel();
|
||||||
|
newModel.NameDE = nameDE;
|
||||||
|
newModel.NameEN = nameEN;
|
||||||
|
newModel.Url = url;
|
||||||
|
|
||||||
|
this.Chairs.Add(newModel);
|
||||||
|
this.hasChanged = true;
|
||||||
|
retValue = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Return the chair model of the chair with the specified name.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="name">name of the chair</param>
|
||||||
|
/// <returns>chair model, if succeeded, otherwise null</returns>
|
||||||
|
public ChairModel GetChairModel(string name)
|
||||||
|
{
|
||||||
|
ChairModel retValue = null;
|
||||||
|
|
||||||
|
foreach (ChairModel temp in this.Chairs)
|
||||||
|
{
|
||||||
|
if (temp.Name.Equals(name) == true)
|
||||||
|
{
|
||||||
|
retValue = temp;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Return true if there were changes in the chair list, otherwise false.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="reset">when true, the hasChanged flag will be reset</param>
|
||||||
|
/// <returns>true, when changed, otherwise false</returns>
|
||||||
|
public bool HasChanged(bool reset = true)
|
||||||
|
{
|
||||||
|
bool retValue = this.hasChanged;
|
||||||
|
|
||||||
|
if (reset == true)
|
||||||
|
{
|
||||||
|
this.hasChanged = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return retValue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -37,6 +37,11 @@ namespace CampusAppWP8.Model.events_news
|
|||||||
if (value != this.item)
|
if (value != this.item)
|
||||||
{
|
{
|
||||||
this.item = value;
|
this.item = value;
|
||||||
|
int i = 0;
|
||||||
|
foreach (RSSModel rssItem in this.item)
|
||||||
|
{
|
||||||
|
rssItem.Index = i++;
|
||||||
|
}
|
||||||
NotifyPropertyChanged("item");
|
NotifyPropertyChanged("item");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -108,6 +108,11 @@ namespace CampusAppWP8.Model.events_news
|
|||||||
get { return String.Format("{0:h:mm} Uhr", this.timestamp); }
|
get { return String.Format("{0:h:mm} Uhr", this.timestamp); }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ListIndex
|
||||||
|
/// </summary>
|
||||||
|
public int Index { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Set/Get the link/url of the feed.
|
/// Set/Get the link/url of the feed.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -1,47 +0,0 @@
|
|||||||
using CampusAppWP8.Model;
|
|
||||||
using System.Collections.ObjectModel;
|
|
||||||
using System.Xml.Serialization;
|
|
||||||
|
|
||||||
namespace CampusAppWP8.Model.events_news
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// ViewModel of the rss feed, containing the feed/channel object.
|
|
||||||
/// </summary>
|
|
||||||
[XmlRoot("root")]
|
|
||||||
public class RSSViewModel : BaseViewModel
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// channel list for the rss feeds.
|
|
||||||
/// </summary>
|
|
||||||
[XmlArray("rss")]
|
|
||||||
[XmlArrayItem("channel")]
|
|
||||||
public ObservableCollection<RSSChannelModel> channel { get; set; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Default constructor.
|
|
||||||
/// </summary>
|
|
||||||
public RSSViewModel()
|
|
||||||
{
|
|
||||||
this.channel = new ObservableCollection<RSSChannelModel>();
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Set/Get the channel list.
|
|
||||||
/// </summary>
|
|
||||||
public ObservableCollection<RSSChannelModel> Channel
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return this.channel;
|
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
if (value != this.channel)
|
|
||||||
{
|
|
||||||
this.channel = value;
|
|
||||||
NotifyPropertyChanged("channel");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
36
CampusAppWP8/CampusAppWP8/Model/GeoDb/PlaceModel.cs
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="PlaceModel.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>08.08.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace CampusAppWP8.Model.GeoDb
|
||||||
|
{
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for a place of the SPSService
|
||||||
|
/// </summary>
|
||||||
|
public class PlaceModel
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the placeId
|
||||||
|
/// </summary>
|
||||||
|
[XmlAttribute("id")]
|
||||||
|
public string PlaceId { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the id of the "parent" of a place
|
||||||
|
/// </summary>
|
||||||
|
[XmlAttribute("parentId")]
|
||||||
|
public string ParentId { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the ReferencePoint of a place
|
||||||
|
/// </summary>
|
||||||
|
[XmlAttribute("refpoint")]
|
||||||
|
public string RefPoint { get; set; }
|
||||||
|
}
|
||||||
|
}
|
||||||
26
CampusAppWP8/CampusAppWP8/Model/GeoDb/SpsModel.cs
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="SpsModel.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>08.08.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace CampusAppWP8.Model.GeoDb
|
||||||
|
{
|
||||||
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for a xml-response of the SPSService
|
||||||
|
/// </summary>
|
||||||
|
[XmlRoot("root")]
|
||||||
|
public class SpsModel
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets a list of places
|
||||||
|
/// </summary>
|
||||||
|
[XmlElement("place")]
|
||||||
|
public ObservableCollection<PlaceModel> Places { get; set; }
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,26 +1,48 @@
|
|||||||
using CampusAppWP8.Utility;
|
//-----------------------------------------------------------------------
|
||||||
using System;
|
// <copyright file="LectureActivity.cs" company="BTU/IIT">
|
||||||
using System.Collections.Generic;
|
// Company copyright tag.
|
||||||
using System.Collections.ObjectModel;
|
// </copyright>
|
||||||
using System.Linq;
|
// <author>stubbfel</author>
|
||||||
using System.Text;
|
// <sience>13.06.2013</sience>
|
||||||
using System.Threading.Tasks;
|
//----------------------------------------------------------------------
|
||||||
using System.Xml.Serialization;
|
|
||||||
|
|
||||||
namespace CampusAppWP8.Model.Lecture
|
namespace CampusAppWP8.Model.Lecture
|
||||||
{
|
{
|
||||||
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
using CampusAppWP8.Utility;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for a Activity
|
||||||
|
/// </summary>
|
||||||
public class LectureActivity
|
public class LectureActivity
|
||||||
{
|
{
|
||||||
#region
|
#region Members
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// List of lecturer
|
||||||
|
/// </summary>
|
||||||
private ObservableCollection<LectureLecturer> lecturer;
|
private ObservableCollection<LectureLecturer> lecturer;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// a formatted string for the names of the lecturers
|
||||||
|
/// </summary>
|
||||||
private string lecturerString;
|
private string lecturerString;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// a formatted string for the names of the courses
|
||||||
|
/// </summary>
|
||||||
private string courseString;
|
private string courseString;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// a formatted string for the topic of the lecture
|
||||||
|
/// </summary>
|
||||||
private string topic;
|
private string topic;
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
#region Constructor
|
#region Constructor
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes a new instance of the <see cref="LectureList" /> class.
|
/// Initializes a new instance of the <see cref="LectureActivity" /> class.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public LectureActivity()
|
public LectureActivity()
|
||||||
{
|
{
|
||||||
@@ -30,41 +52,72 @@ namespace CampusAppWP8.Model.Lecture
|
|||||||
|
|
||||||
#region Proberty
|
#region Proberty
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the type of the activity
|
||||||
|
/// </summary>
|
||||||
[XmlElement("art")]
|
[XmlElement("art")]
|
||||||
public string Type { get; set; }
|
public string Type { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the id of the activity
|
||||||
|
/// </summary>
|
||||||
[XmlAttribute("id")]
|
[XmlAttribute("id")]
|
||||||
public int Id { get; set; }
|
public int Id { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets semester of the activity
|
||||||
|
/// </summary>
|
||||||
[XmlElement("semester")]
|
[XmlElement("semester")]
|
||||||
public int Semester { get; set; }
|
public int Semester { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the contact hour
|
||||||
|
/// </summary>
|
||||||
[XmlElement("sws")]
|
[XmlElement("sws")]
|
||||||
public string SWS { get; set; }
|
public string SWS { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets LectureModule
|
||||||
|
/// </summary>
|
||||||
[XmlElement("modul")]
|
[XmlElement("modul")]
|
||||||
public LectureModul Modul { get; set; }
|
public LectureModule Modul { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets LectureTitle
|
||||||
|
/// </summary>
|
||||||
|
[XmlElement("titel")]
|
||||||
|
public string Title { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the lecturers
|
||||||
|
/// </summary>
|
||||||
[XmlElement("lehrperson")]
|
[XmlElement("lehrperson")]
|
||||||
public ObservableCollection<LectureLecturer> Lecturer {
|
public ObservableCollection<LectureLecturer> Lecturer
|
||||||
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
return lecturer;
|
return this.lecturer;
|
||||||
}
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value != lecturer)
|
if (value != this.lecturer)
|
||||||
{
|
{
|
||||||
lecturer = value;
|
this.lecturer = value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public string LecturerString {
|
/// <summary>
|
||||||
|
/// Gets or sets the formatted string of the lecturers
|
||||||
|
/// </summary>
|
||||||
|
public string LecturerString
|
||||||
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
return this.lecturerString;
|
return this.lecturerString;
|
||||||
}
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value != this.lecturerString)
|
if (value != this.lecturerString)
|
||||||
@@ -74,12 +127,16 @@ namespace CampusAppWP8.Model.Lecture
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets formatted string of the courses
|
||||||
|
/// </summary>
|
||||||
public string CourseString
|
public string CourseString
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
return this.courseString;
|
return this.courseString;
|
||||||
}
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value != this.courseString)
|
if (value != this.courseString)
|
||||||
@@ -89,52 +146,76 @@ namespace CampusAppWP8.Model.Lecture
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the courses
|
||||||
|
/// </summary>
|
||||||
[XmlElement("studiengang")]
|
[XmlElement("studiengang")]
|
||||||
public ObservableCollection<LectureCourse> Course { get; set; }
|
public ObservableCollection<LectureCourse> Course { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the dates of the activity
|
||||||
|
/// </summary>
|
||||||
[XmlElement("termin")]
|
[XmlElement("termin")]
|
||||||
public ObservableCollection<LectureDate> Dates { get; set; }
|
public ObservableCollection<LectureDate> Dates { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the Department
|
||||||
|
/// </summary>
|
||||||
[XmlElement("zugeordnete_einrichtung")]
|
[XmlElement("zugeordnete_einrichtung")]
|
||||||
public string Department { get; set; }
|
public string Department { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the topic of the Lecture
|
||||||
|
/// </summary>
|
||||||
[XmlElement("lehrinhalt")]
|
[XmlElement("lehrinhalt")]
|
||||||
public string Topic
|
public string Topic
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
return topic;
|
return this.topic;
|
||||||
}
|
}
|
||||||
|
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value != topic)
|
if (value != this.topic)
|
||||||
{
|
{
|
||||||
topic = StringManager.StripHTML(value);
|
this.topic = StringManager.StripHTML(value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
public void createLectureString()
|
#region Methods
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method create a formatted string of the LecturerList
|
||||||
|
/// </summary>
|
||||||
|
public void CreateLectureString()
|
||||||
{
|
{
|
||||||
string result = string.Empty;
|
string result = string.Empty;
|
||||||
foreach (LectureLecturer tmpLecturer in Lecturer)
|
foreach (LectureLecturer tmpLecturer in this.Lecturer)
|
||||||
{
|
{
|
||||||
result += tmpLecturer.ToString() + "\n";
|
result += StringManager.AddNewLine(tmpLecturer.ToString());
|
||||||
}
|
}
|
||||||
this.LecturerString = result.TrimEnd('\n');
|
|
||||||
|
this.LecturerString = StringManager.RemvoveNewLine(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void createCourseString()
|
/// <summary>
|
||||||
|
/// Method create a formatted string of the CourseList
|
||||||
|
/// </summary>
|
||||||
|
public void CreateCourseString()
|
||||||
{
|
{
|
||||||
string result = string.Empty;
|
string result = string.Empty;
|
||||||
foreach (LectureCourse course in Course)
|
foreach (LectureCourse course in this.Course)
|
||||||
{
|
{
|
||||||
result += course.Title + "\n";
|
result += StringManager.AddNewLine(course.Title);
|
||||||
}
|
}
|
||||||
this.CourseString = result.TrimEnd('\n');
|
|
||||||
|
this.CourseString = StringManager.RemvoveNewLine(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,17 +1,29 @@
|
|||||||
using System;
|
// <copyright file="LectureCourse.cs" company="BTU/IIT">
|
||||||
using System.Collections.Generic;
|
// Company copyright tag.
|
||||||
using System.Linq;
|
// </copyright>
|
||||||
using System.Text;
|
// <author>stubbfel</author>
|
||||||
using System.Xml.Serialization;
|
// <sience>10.06.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
namespace CampusAppWP8.Model.Lecture
|
namespace CampusAppWP8.Model.Lecture
|
||||||
{
|
{
|
||||||
public class LectureCourse
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for a course
|
||||||
|
/// </summary>
|
||||||
|
public class LectureCourse
|
||||||
{
|
{
|
||||||
public LectureCourse()
|
/// <summary>
|
||||||
{
|
/// Initializes a new instance of the <see cref="LectureCourse" /> class.
|
||||||
}
|
/// </summary>
|
||||||
[XmlElement("bezeichnung")]
|
public LectureCourse()
|
||||||
public string Title {get;set;}
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the title of the course
|
||||||
|
/// </summary>
|
||||||
|
[XmlElement("bezeichnung")]
|
||||||
|
public string Title { get; set; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,31 +1,66 @@
|
|||||||
using System;
|
//-----------------------------------------------------------------------
|
||||||
using System.Collections.Generic;
|
// <copyright file="LectureDate.cs" company="BTU/IIT">
|
||||||
using System.Linq;
|
// Company copyright tag.
|
||||||
using System.Text;
|
// </copyright>
|
||||||
using System.Xml.Serialization;
|
// <author>stubbfel</author>
|
||||||
|
// <sience>10.06.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
namespace CampusAppWP8.Model.Lecture
|
namespace CampusAppWP8.Model.Lecture
|
||||||
{
|
{
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for the date of an activity
|
||||||
|
/// </summary>
|
||||||
public class LectureDate
|
public class LectureDate
|
||||||
{
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="LectureDate" /> class.
|
||||||
|
/// </summary>
|
||||||
public LectureDate()
|
public LectureDate()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets WeekDay
|
||||||
|
/// </summary>
|
||||||
[XmlElement("wochentag")]
|
[XmlElement("wochentag")]
|
||||||
public string WeekDay { get; set; }
|
public string WeekDay { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets From
|
||||||
|
/// </summary>
|
||||||
[XmlElement("von")]
|
[XmlElement("von")]
|
||||||
public string From { get; set; }
|
public string From { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets To
|
||||||
|
/// </summary>
|
||||||
[XmlElement("bis")]
|
[XmlElement("bis")]
|
||||||
public string To { get; set; }
|
public string To { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets Interval
|
||||||
|
/// </summary>
|
||||||
[XmlElement("rhythmus")]
|
[XmlElement("rhythmus")]
|
||||||
public string Interval { get; set; }
|
public string Interval { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets Room
|
||||||
|
/// </summary>
|
||||||
[XmlElement("raum")]
|
[XmlElement("raum")]
|
||||||
public string Room { get; set; }
|
public string Room { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets StartDate
|
||||||
|
/// </summary>
|
||||||
[XmlElement("anfangsdatum")]
|
[XmlElement("anfangsdatum")]
|
||||||
public string StarDate { get; set; }
|
public string StartDate { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets EndDate
|
||||||
|
/// </summary>
|
||||||
[XmlElement("enddatum")]
|
[XmlElement("enddatum")]
|
||||||
public string EndDate { get; set; }
|
public string EndDate { get; set; }
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,45 +1,71 @@
|
|||||||
using System;
|
//-----------------------------------------------------------------------
|
||||||
using System.Collections.Generic;
|
// <copyright file="LectureLecturer.cs" company="BTU/IIT">
|
||||||
using System.Linq;
|
// Company copyright tag.
|
||||||
using System.Text;
|
// </copyright>
|
||||||
using System.Xml.Serialization;
|
// <author>stubbfel</author>
|
||||||
|
// <sience>10.06.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
namespace CampusAppWP8.Model.Lecture
|
namespace CampusAppWP8.Model.Lecture
|
||||||
{
|
{
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for a lecturer
|
||||||
|
/// </summary>
|
||||||
public class LectureLecturer
|
public class LectureLecturer
|
||||||
{
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="LectureLecturer" /> class.
|
||||||
|
/// </summary>
|
||||||
public LectureLecturer()
|
public LectureLecturer()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the FirstName of a lecturer
|
||||||
|
/// </summary>
|
||||||
[XmlElement("vorname")]
|
[XmlElement("vorname")]
|
||||||
public string FirstName { get; set; }
|
public string FirstName { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the LastName of a lecturer
|
||||||
|
/// </summary>
|
||||||
[XmlElement("name")]
|
[XmlElement("name")]
|
||||||
public string LastName { get; set; }
|
public string LastName { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the title of a lecturer
|
||||||
|
/// </summary>
|
||||||
[XmlElement("titel")]
|
[XmlElement("titel")]
|
||||||
public string Title { get; set; }
|
public string Title { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the Responsibility of a lecturer
|
||||||
|
/// </summary>
|
||||||
[XmlAttribute("zustaendigkeit")]
|
[XmlAttribute("zustaendigkeit")]
|
||||||
public string Responsibility { get; set; }
|
public string Responsibility { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method overrides the base ToString() and create an formatted string of the lecturer
|
||||||
|
/// </summary>
|
||||||
|
/// <returns>returns a string like: [Title] FirstName LastName [(Responsibility)]</returns>
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
{
|
{
|
||||||
string result = string.Empty;
|
string result = string.Empty;
|
||||||
|
|
||||||
if (!Title.Equals(string.Empty))
|
if (!this.Title.Equals(string.Empty))
|
||||||
{
|
{
|
||||||
result += Title + " ";
|
result += this.Title + " ";
|
||||||
}
|
}
|
||||||
|
|
||||||
result += FirstName + " ";
|
result += this.FirstName + " ";
|
||||||
result += LastName + " ";
|
result += this.LastName + " ";
|
||||||
|
|
||||||
if (!Responsibility.Equals(string.Empty))
|
if (!this.Responsibility.Equals(string.Empty))
|
||||||
{
|
{
|
||||||
result += "(" + Responsibility + ") ";
|
result += "(" + this.Responsibility + ") ";
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,15 +7,16 @@
|
|||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
namespace CampusAppWP8.Model.Lecture
|
namespace CampusAppWP8.Model.Lecture
|
||||||
{
|
{
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Collections.ObjectModel;
|
using System.Collections.ObjectModel;
|
||||||
using System.Xml.Serialization;
|
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for a List of LectureActivity
|
||||||
|
/// </summary>
|
||||||
[XmlRoot("lsf_auszug")]
|
[XmlRoot("lsf_auszug")]
|
||||||
public class LectureList
|
public class LectureList
|
||||||
{
|
{
|
||||||
|
|
||||||
#region Constructor
|
#region Constructor
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -29,6 +30,9 @@ namespace CampusAppWP8.Model.Lecture
|
|||||||
|
|
||||||
#region Proberty
|
#region Proberty
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets List of the activities
|
||||||
|
/// </summary>
|
||||||
[XmlArray("veranstaltungsliste")]
|
[XmlArray("veranstaltungsliste")]
|
||||||
[XmlArrayItem("veranstaltung")]
|
[XmlArrayItem("veranstaltung")]
|
||||||
public ObservableCollection<LectureActivity> Activities { get; set; }
|
public ObservableCollection<LectureActivity> Activities { get; set; }
|
||||||
@@ -37,12 +41,17 @@ namespace CampusAppWP8.Model.Lecture
|
|||||||
|
|
||||||
#region Methods
|
#region Methods
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method return a certain activity
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="id"> id of the activity</param>
|
||||||
|
/// <returns> the activity (FirstOrDefault)</returns>
|
||||||
public LectureActivity GetActivity(int id)
|
public LectureActivity GetActivity(int id)
|
||||||
{
|
{
|
||||||
LectureActivity activity = Activities.Where(p => p.Id == id).First();
|
LectureActivity activity = this.Activities.Where(p => p.Id == id).FirstOrDefault();
|
||||||
return activity;
|
return activity;
|
||||||
}
|
}
|
||||||
#endregion
|
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,70 +0,0 @@
|
|||||||
//-----------------------------------------------------------------------
|
|
||||||
// <copyright file="LectureModul.cs" company="BTU/IIT">
|
|
||||||
// Company copyright tag.
|
|
||||||
// </copyright>
|
|
||||||
// <author>stubbfel</author>
|
|
||||||
// <sience>10.06.2013</sience>
|
|
||||||
//----------------------------------------------------------------------
|
|
||||||
namespace CampusAppWP8.Model.Lecture
|
|
||||||
{
|
|
||||||
using CampusAppWP8.Resources;
|
|
||||||
using System;
|
|
||||||
using System.Xml.Serialization;
|
|
||||||
public class LectureModul
|
|
||||||
{
|
|
||||||
#region Members
|
|
||||||
|
|
||||||
private int number;
|
|
||||||
|
|
||||||
private Uri url;
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region Constructor
|
|
||||||
|
|
||||||
public LectureModul()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region Property
|
|
||||||
|
|
||||||
[XmlElement("titel")]
|
|
||||||
public string Title {get; set;}
|
|
||||||
|
|
||||||
[XmlElement("nummer")]
|
|
||||||
public int Number{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return this.number;
|
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
if (value != this.number)
|
|
||||||
{
|
|
||||||
this.number = value;
|
|
||||||
this.createUrl();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public Uri Url{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return url;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region Methods
|
|
||||||
|
|
||||||
private void createUrl()
|
|
||||||
{
|
|
||||||
this.url = new Uri(Constants.UrlLectureModulBaseAddr + number.ToString());
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
}
|
|
||||||
}
|
|
||||||
98
CampusAppWP8/CampusAppWP8/Model/Lecture/LectureModule.cs
Normal file
@@ -0,0 +1,98 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="LectureModule.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>10.06.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.Model.Lecture
|
||||||
|
{
|
||||||
|
using System;
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
using CampusAppWP8.Resources;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for the module of an lecture
|
||||||
|
/// </summary>
|
||||||
|
public class LectureModule
|
||||||
|
{
|
||||||
|
#region Members
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Number of the module (like an id)
|
||||||
|
/// </summary>
|
||||||
|
private int number;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Url to the website of the module
|
||||||
|
/// </summary>
|
||||||
|
private Uri url;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Constructor
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="LectureModule" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public LectureModule()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Property
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the title of the module
|
||||||
|
/// </summary>
|
||||||
|
[XmlElement("titel")]
|
||||||
|
public string Title { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the number of the module and create the URL
|
||||||
|
/// </summary>
|
||||||
|
[XmlElement("nummer")]
|
||||||
|
public int Number
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.number;
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if (value != this.number)
|
||||||
|
{
|
||||||
|
this.number = value;
|
||||||
|
this.CreateUrl();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the URL of the module
|
||||||
|
/// </summary>
|
||||||
|
public Uri Url
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.url;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Methods
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method create the url of the module
|
||||||
|
/// </summary>
|
||||||
|
private void CreateUrl()
|
||||||
|
{
|
||||||
|
this.url = new Uri(Constants.UrlLecture_ModulBaseAddr + this.number.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
326
CampusAppWP8/CampusAppWP8/Model/Lecture/LecturePageModel.cs
Normal file
@@ -0,0 +1,326 @@
|
|||||||
|
//-----------------------------------------------------------------------
|
||||||
|
// <copyright file="LecturePageModel.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>18.06.2013</sience>
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
namespace CampusAppWP8.Model.Lecture
|
||||||
|
{
|
||||||
|
using System.Runtime.Serialization;
|
||||||
|
using CampusAppWP8.Model.Setting;
|
||||||
|
using CampusAppWP8.Model.Utility;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for the LecturePage
|
||||||
|
/// </summary>
|
||||||
|
[DataContract]
|
||||||
|
public class LecturePageModel
|
||||||
|
{
|
||||||
|
#region Members
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Variable for the courseIndex
|
||||||
|
/// </summary>
|
||||||
|
[DataMember]
|
||||||
|
public int selectCourseIndex;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Variable for the degreeIndex
|
||||||
|
/// </summary>
|
||||||
|
[DataMember]
|
||||||
|
public int selectDegreeIndex;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Variable for the semesterIndex
|
||||||
|
/// </summary>
|
||||||
|
[DataMember]
|
||||||
|
public int selectSemesterIndex;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Variable for the fromIndex
|
||||||
|
/// </summary>
|
||||||
|
[DataMember]
|
||||||
|
public int selectFromIndex;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Variable for the toIndex
|
||||||
|
/// </summary>
|
||||||
|
[DataMember]
|
||||||
|
public int selectToIndex;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// List for the courses of the BTU
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// need to be extend to full list
|
||||||
|
/// </remarks>
|
||||||
|
private ListPickerItemListModel courseList;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// List of the degrees
|
||||||
|
/// </summary>
|
||||||
|
private ListPickerItemListModel degreeList;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// List of the semester
|
||||||
|
/// </summary>
|
||||||
|
private ListPickerItemListModel semesterList;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// List for the number of semester (from)
|
||||||
|
/// </summary>
|
||||||
|
private ListPickerItemListModel fromNumberList;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// List for the number of semester (to)
|
||||||
|
/// </summary>
|
||||||
|
private ListPickerItemListModel toNumberList;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Constructor
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="LecturePageModel" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public LecturePageModel()
|
||||||
|
{
|
||||||
|
this.courseList = new CourseListPickerItemListModel();
|
||||||
|
this.degreeList = new DegreeListPickerItemListModel();
|
||||||
|
this.semesterList = new SemesterListPickerItemListModel();
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Proberty
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the selected course index
|
||||||
|
/// </summary>
|
||||||
|
public int SelectCourseIndex
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.selectCourseIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if (value != this.selectCourseIndex && this.courseList != null && value < this.courseList.List.Count)
|
||||||
|
{
|
||||||
|
this.selectCourseIndex = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the selected degree index
|
||||||
|
/// </summary>
|
||||||
|
public int SelectDegreeIndex
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.selectDegreeIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if (value != this.selectDegreeIndex && this.degreeList != null && value < this.degreeList.List.Count)
|
||||||
|
{
|
||||||
|
this.selectDegreeIndex = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the selected semester-index
|
||||||
|
/// </summary>
|
||||||
|
public int SelectSemesterIndex
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.selectSemesterIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if (value != this.selectSemesterIndex && this.semesterList != null && value < this.semesterList.List.Count)
|
||||||
|
{
|
||||||
|
this.selectSemesterIndex = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the selected from-index
|
||||||
|
/// </summary>
|
||||||
|
public int SelectFromIndex
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.selectFromIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if (value != this.selectFromIndex && this.fromNumberList != null && value < this.fromNumberList.List.Count)
|
||||||
|
{
|
||||||
|
this.selectFromIndex = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets the selected to-index
|
||||||
|
/// </summary>
|
||||||
|
public int SelectToIndex
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.selectToIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if (value != this.selectToIndex && this.toNumberList != null && value < this.toNumberList.List.Count)
|
||||||
|
{
|
||||||
|
this.selectToIndex = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets List for the courses of the BTU
|
||||||
|
/// </summary>
|
||||||
|
public ListPickerItemListModel CourseList
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.courseList;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets List of the degrees
|
||||||
|
/// </summary>
|
||||||
|
public ListPickerItemListModel DegreeList
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.degreeList;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets List of the semester
|
||||||
|
/// </summary>
|
||||||
|
public ListPickerItemListModel SemesterList
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.semesterList;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets List for the number of semester
|
||||||
|
/// </summary>
|
||||||
|
public ListPickerItemListModel FromNumberList
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.fromNumberList;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the NumberList
|
||||||
|
/// </summary>
|
||||||
|
public ListPickerItemListModel ToNumberList
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.toNumberList;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Methods
|
||||||
|
|
||||||
|
#region public
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Load all ListPickerLists
|
||||||
|
/// </summary>
|
||||||
|
public void LoadLists()
|
||||||
|
{
|
||||||
|
this.LoadFromNumberList();
|
||||||
|
this.LoadToNumberList();
|
||||||
|
UserProfilModel userModel = Settings.UserProfil.Model;
|
||||||
|
this.selectCourseIndex = this.courseList.GetIndexOrDefault(((int)userModel.Course).ToString().PadLeft(3, '0'));
|
||||||
|
this.selectDegreeIndex = this.degreeList.GetIndexOrDefault(((int)userModel.Degree).ToString());
|
||||||
|
this.selectSemesterIndex = this.semesterList.GetIndexOrDefault(((int)userModel.Semester).ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region private
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Load the NumberList
|
||||||
|
/// </summary>
|
||||||
|
public void LoadFromNumberList()
|
||||||
|
{
|
||||||
|
string selectValue = null;
|
||||||
|
if (this.fromNumberList != null && this.fromNumberList.List.Count > 0)
|
||||||
|
{
|
||||||
|
selectValue = this.fromNumberList.List[this.SelectFromIndex].Value;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.fromNumberList = this.CreateNumberList(1, 10);
|
||||||
|
this.SelectFromIndex = this.fromNumberList.GetIndexOrDefault(selectValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Load the NumberList
|
||||||
|
/// </summary>
|
||||||
|
public void LoadToNumberList()
|
||||||
|
{
|
||||||
|
string selectValue = null;
|
||||||
|
if (this.toNumberList != null && this.toNumberList.List.Count > 0)
|
||||||
|
{
|
||||||
|
selectValue = this.toNumberList.List[this.SelectToIndex].Value;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.toNumberList = this.CreateNumberList(this.SelectFromIndex + 1, 10);
|
||||||
|
this.SelectToIndex = this.toNumberList.GetIndexOrDefault(selectValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Method create a NumberList
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="startvalue">startValue of the list</param>
|
||||||
|
/// <param name="endvalue">endValue of the list</param>
|
||||||
|
/// <returns>return list</returns>
|
||||||
|
private ListPickerItemListModel CreateNumberList(int startvalue, int endvalue)
|
||||||
|
{
|
||||||
|
ListPickerItemListModel list = new ListPickerItemListModel();
|
||||||
|
string degree = this.DegreeList.List[this.SelectDegreeIndex].Value;
|
||||||
|
|
||||||
|
for (int i = startvalue; i <= endvalue; i++)
|
||||||
|
{
|
||||||
|
if ((i > 4 && "88".Equals(degree)) || (i > 6 && "82".Equals(degree)))
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
list.AddItem(i.ToString(), i.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
64
CampusAppWP8/CampusAppWP8/Model/Link/LinkListModel.cs
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// <copyright file="LinkListModel.cs" company="BTU/IIT">
|
||||||
|
// Company copyright tag.
|
||||||
|
// </copyright>
|
||||||
|
// <author>stubbfel</author>
|
||||||
|
// <sience>02.07.2013</sience>
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace CampusAppWP8.Model.Link
|
||||||
|
{
|
||||||
|
using System;
|
||||||
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Xml.Serialization;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Model for a list of links.
|
||||||
|
/// </summary>
|
||||||
|
[XmlRoot("root")]
|
||||||
|
public class LinkListModel
|
||||||
|
{
|
||||||
|
#region Member
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Time when the model was created.
|
||||||
|
/// </summary>
|
||||||
|
private readonly DateTime createTime;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Constructor
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="LinkListModel" /> class.
|
||||||
|
/// </summary>
|
||||||
|
public LinkListModel()
|
||||||
|
{
|
||||||
|
this.createTime = DateTime.Now;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Property
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets or sets feed information item list.
|
||||||
|
/// </summary>
|
||||||
|
[XmlArray("data")]
|
||||||
|
[XmlArrayItem("link")]
|
||||||
|
public ObservableCollection<LinkModel> Links { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the creation time of the model.
|
||||||
|
/// </summary>
|
||||||
|
public DateTime CreateTime
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return this.createTime;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||