From 704e3796a0839d389995f14617493c4817c30208 Mon Sep 17 00:00:00 2001 From: Dani Palou Date: Thu, 7 Dec 2017 10:39:11 +0100 Subject: [PATCH] MOBILE-2302 mainmenu: Implement delegate and Main Menu page --- src/core/login/providers/helper.ts | 81 ++++---- src/core/mainmenu/lang/ar.json | 8 + src/core/mainmenu/lang/bg.json | 8 + src/core/mainmenu/lang/ca.json | 9 + src/core/mainmenu/lang/cs.json | 9 + src/core/mainmenu/lang/da.json | 9 + src/core/mainmenu/lang/de-du.json | 9 + src/core/mainmenu/lang/de.json | 9 + src/core/mainmenu/lang/el.json | 9 + src/core/mainmenu/lang/en.json | 9 + src/core/mainmenu/lang/es-mx.json | 9 + src/core/mainmenu/lang/es.json | 9 + src/core/mainmenu/lang/eu.json | 9 + src/core/mainmenu/lang/fa.json | 8 + src/core/mainmenu/lang/fi.json | 9 + src/core/mainmenu/lang/fr.json | 9 + src/core/mainmenu/lang/he.json | 9 + src/core/mainmenu/lang/hr.json | 8 + src/core/mainmenu/lang/hu.json | 7 + src/core/mainmenu/lang/it.json | 9 + src/core/mainmenu/lang/ja.json | 8 + src/core/mainmenu/lang/lt.json | 9 + src/core/mainmenu/lang/mr.json | 9 + src/core/mainmenu/lang/nl.json | 9 + src/core/mainmenu/lang/no.json | 5 + src/core/mainmenu/lang/pl.json | 7 + src/core/mainmenu/lang/pt-br.json | 9 + src/core/mainmenu/lang/pt.json | 9 + src/core/mainmenu/lang/ro.json | 9 + src/core/mainmenu/lang/ru.json | 8 + src/core/mainmenu/lang/sr-cr.json | 9 + src/core/mainmenu/lang/sr-lt.json | 9 + src/core/mainmenu/lang/sv.json | 8 + src/core/mainmenu/lang/tr.json | 7 + src/core/mainmenu/lang/uk.json | 9 + src/core/mainmenu/lang/zh-cn.json | 7 + src/core/mainmenu/lang/zh-tw.json | 9 + src/core/mainmenu/mainmenu.module.ts | 27 +++ src/core/mainmenu/pages/menu/menu.html | 3 + src/core/mainmenu/pages/menu/menu.module.ts | 31 +++ src/core/mainmenu/pages/menu/menu.scss | 3 + src/core/mainmenu/pages/menu/menu.ts | 72 +++++++ src/core/mainmenu/providers/delegate.ts | 202 ++++++++++++++++++++ src/lang/en.json | 1 + 44 files changed, 687 insertions(+), 38 deletions(-) create mode 100644 src/core/mainmenu/lang/ar.json create mode 100644 src/core/mainmenu/lang/bg.json create mode 100644 src/core/mainmenu/lang/ca.json create mode 100644 src/core/mainmenu/lang/cs.json create mode 100644 src/core/mainmenu/lang/da.json create mode 100644 src/core/mainmenu/lang/de-du.json create mode 100644 src/core/mainmenu/lang/de.json create mode 100644 src/core/mainmenu/lang/el.json create mode 100644 src/core/mainmenu/lang/en.json create mode 100644 src/core/mainmenu/lang/es-mx.json create mode 100644 src/core/mainmenu/lang/es.json create mode 100644 src/core/mainmenu/lang/eu.json create mode 100644 src/core/mainmenu/lang/fa.json create mode 100644 src/core/mainmenu/lang/fi.json create mode 100644 src/core/mainmenu/lang/fr.json create mode 100644 src/core/mainmenu/lang/he.json create mode 100644 src/core/mainmenu/lang/hr.json create mode 100644 src/core/mainmenu/lang/hu.json create mode 100644 src/core/mainmenu/lang/it.json create mode 100644 src/core/mainmenu/lang/ja.json create mode 100644 src/core/mainmenu/lang/lt.json create mode 100644 src/core/mainmenu/lang/mr.json create mode 100644 src/core/mainmenu/lang/nl.json create mode 100644 src/core/mainmenu/lang/no.json create mode 100644 src/core/mainmenu/lang/pl.json create mode 100644 src/core/mainmenu/lang/pt-br.json create mode 100644 src/core/mainmenu/lang/pt.json create mode 100644 src/core/mainmenu/lang/ro.json create mode 100644 src/core/mainmenu/lang/ru.json create mode 100644 src/core/mainmenu/lang/sr-cr.json create mode 100644 src/core/mainmenu/lang/sr-lt.json create mode 100644 src/core/mainmenu/lang/sv.json create mode 100644 src/core/mainmenu/lang/tr.json create mode 100644 src/core/mainmenu/lang/uk.json create mode 100644 src/core/mainmenu/lang/zh-cn.json create mode 100644 src/core/mainmenu/lang/zh-tw.json create mode 100644 src/core/mainmenu/mainmenu.module.ts create mode 100644 src/core/mainmenu/pages/menu/menu.html create mode 100644 src/core/mainmenu/pages/menu/menu.module.ts create mode 100644 src/core/mainmenu/pages/menu/menu.scss create mode 100644 src/core/mainmenu/pages/menu/menu.ts create mode 100644 src/core/mainmenu/providers/delegate.ts diff --git a/src/core/login/providers/helper.ts b/src/core/login/providers/helper.ts index 2a61eaa71..d6baa15d7 100644 --- a/src/core/login/providers/helper.ts +++ b/src/core/login/providers/helper.ts @@ -379,49 +379,54 @@ export class CoreLoginHelperProvider { * @return {Promise} Promise resolved when done. */ goToSiteInitialPage(navCtrl: NavController, setRoot?: boolean) : Promise { - return this.isMyOverviewEnabled().then((myOverview) => { - let myCourses = !myOverview && this.isMyCoursesEnabled(), - site = this.sitesProvider.getCurrentSite(), - promise; + if (setRoot) { + return navCtrl.setRoot('CoreMainMenuPage', {}, {animate: false}); + } else { + return navCtrl.push('CoreMainMenuPage'); + } + // return this.isMyOverviewEnabled().then((myOverview) => { + // let myCourses = !myOverview && this.isMyCoursesEnabled(), + // site = this.sitesProvider.getCurrentSite(), + // promise; - if (!site) { - return Promise.reject(null); - } + // if (!site) { + // return Promise.reject(null); + // } - // Check if frontpage is needed to be shown. (If configured or if any of the other avalaible). - if ((site.getInfo() && site.getInfo().userhomepage === 0) || (!myCourses && !myOverview)) { - promise = this.isFrontpageEnabled(); - } else { - promise = Promise.resolve(false); - } + // // Check if frontpage is needed to be shown. (If configured or if any of the other avalaible). + // if ((site.getInfo() && site.getInfo().userhomepage === 0) || (!myCourses && !myOverview)) { + // promise = this.isFrontpageEnabled(); + // } else { + // promise = Promise.resolve(false); + // } - return promise.then((frontpage) => { - // Check avalaibility in priority order. - let pageName, - params; + // return promise.then((frontpage) => { + // // Check avalaibility in priority order. + // let pageName, + // params; - // @todo Use real pages names when they are implemented. - if (frontpage) { - pageName = 'Frontpage'; - } else if (myOverview) { - pageName = 'MyOverview'; - } else if (myCourses) { - pageName = 'MyCourses'; - } else { - // Anything else available, go to the user profile. - pageName = 'User'; - params = { - userId: site.getUserId() - }; - } + // // @todo Use real pages names when they are implemented. + // if (frontpage) { + // pageName = 'Frontpage'; + // } else if (myOverview) { + // pageName = 'MyOverview'; + // } else if (myCourses) { + // pageName = 'MyCourses'; + // } else { + // // Anything else available, go to the user profile. + // pageName = 'User'; + // params = { + // userId: site.getUserId() + // }; + // } - if (setRoot) { - return navCtrl.setRoot(pageName, params, {animate: false}); - } else { - return navCtrl.push(pageName, params); - } - }); - }); + // if (setRoot) { + // return navCtrl.setRoot(pageName, params, {animate: false}); + // } else { + // return navCtrl.push(pageName, params); + // } + // }); + // }); } /** diff --git a/src/core/mainmenu/lang/ar.json b/src/core/mainmenu/lang/ar.json new file mode 100644 index 000000000..79a0f6adb --- /dev/null +++ b/src/core/mainmenu/lang/ar.json @@ -0,0 +1,8 @@ +{ + "appsettings": "إعدادات التطبيق", + "changesite": "الخروج", + "help": "مساعدة", + "logout": "خروج", + "mycourses": "مقرراتي الدراسية", + "website": "الموقع" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/bg.json b/src/core/mainmenu/lang/bg.json new file mode 100644 index 000000000..3ccb973aa --- /dev/null +++ b/src/core/mainmenu/lang/bg.json @@ -0,0 +1,8 @@ +{ + "appsettings": "Настройки на приложението", + "changesite": "Изход", + "help": "Помощ", + "logout": "Изход", + "mycourses": "Моите курсове", + "website": "Уебсайт" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/ca.json b/src/core/mainmenu/lang/ca.json new file mode 100644 index 000000000..d2e61d92b --- /dev/null +++ b/src/core/mainmenu/lang/ca.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Paràmetres de l'aplicació", + "changesite": "Canvia de lloc", + "help": "Ajuda", + "logout": "Surt", + "mycourses": "Els meus cursos", + "togglemenu": "Canvia menú", + "website": "Lloc web" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/cs.json b/src/core/mainmenu/lang/cs.json new file mode 100644 index 000000000..68c7fe8de --- /dev/null +++ b/src/core/mainmenu/lang/cs.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Nastavení aplikace", + "changesite": "Změnit stránky", + "help": "Pomoc", + "logout": "Odhlásit se", + "mycourses": "Moje kurzy", + "togglemenu": "Přepnout nabídku", + "website": "Webová stránka" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/da.json b/src/core/mainmenu/lang/da.json new file mode 100644 index 000000000..9384a37c6 --- /dev/null +++ b/src/core/mainmenu/lang/da.json @@ -0,0 +1,9 @@ +{ + "appsettings": "App-indstillinger", + "changesite": "Skift side", + "help": "Hjælp", + "logout": "Log ud", + "mycourses": "Mine kurser", + "togglemenu": "Skift menu", + "website": "Websted" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/de-du.json b/src/core/mainmenu/lang/de-du.json new file mode 100644 index 000000000..4f3285f04 --- /dev/null +++ b/src/core/mainmenu/lang/de-du.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Einstellungen", + "changesite": "Website wechseln", + "help": "Hilfe", + "logout": "Abmelden", + "mycourses": "Meine Kurse", + "togglemenu": "Menü umschalten", + "website": "Website im Browser" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/de.json b/src/core/mainmenu/lang/de.json new file mode 100644 index 000000000..4f3285f04 --- /dev/null +++ b/src/core/mainmenu/lang/de.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Einstellungen", + "changesite": "Website wechseln", + "help": "Hilfe", + "logout": "Abmelden", + "mycourses": "Meine Kurse", + "togglemenu": "Menü umschalten", + "website": "Website im Browser" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/el.json b/src/core/mainmenu/lang/el.json new file mode 100644 index 000000000..114771adb --- /dev/null +++ b/src/core/mainmenu/lang/el.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Ρυθμίσεις εφαρμογής", + "changesite": "Αλλαγή ιστότοπου", + "help": "Βοήθεια", + "logout": "Έξοδος", + "mycourses": "Τα μαθήματά μου", + "togglemenu": "Αλλαγή μενού", + "website": "Ιστότοπος" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/en.json b/src/core/mainmenu/lang/en.json new file mode 100644 index 000000000..dfa7b11f4 --- /dev/null +++ b/src/core/mainmenu/lang/en.json @@ -0,0 +1,9 @@ +{ + "appsettings": "App settings", + "changesite": "Change site", + "help": "Help", + "logout": "Log out", + "mycourses": "My courses", + "togglemenu": "Toggle menu", + "website": "Website" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/es-mx.json b/src/core/mainmenu/lang/es-mx.json new file mode 100644 index 000000000..fb36a0997 --- /dev/null +++ b/src/core/mainmenu/lang/es-mx.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Configuraciones del App", + "changesite": "Cambiar sitio", + "help": "Ayuda", + "logout": "Salir", + "mycourses": "Mis cursos", + "togglemenu": "Alternar menú", + "website": "Página web" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/es.json b/src/core/mainmenu/lang/es.json new file mode 100644 index 000000000..e826092d7 --- /dev/null +++ b/src/core/mainmenu/lang/es.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Configuración de la aplicación", + "changesite": "Cambiar de sitio", + "help": "Ayuda", + "logout": "Salir", + "mycourses": "Mis cursos", + "togglemenu": "Cambiar menú", + "website": "Página web" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/eu.json b/src/core/mainmenu/lang/eu.json new file mode 100644 index 000000000..c5757719d --- /dev/null +++ b/src/core/mainmenu/lang/eu.json @@ -0,0 +1,9 @@ +{ + "appsettings": "App-aren ezarpenak", + "changesite": "Aldatu gunea", + "help": "Laguntza", + "logout": "Saioa amaitu", + "mycourses": "Nire ikastaroak", + "togglemenu": "Aldatu menua", + "website": "Webgunea" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/fa.json b/src/core/mainmenu/lang/fa.json new file mode 100644 index 000000000..34bdcc701 --- /dev/null +++ b/src/core/mainmenu/lang/fa.json @@ -0,0 +1,8 @@ +{ + "appsettings": "تنظیمات برنامه", + "changesite": "خروج", + "help": "راهنمایی", + "logout": "خروج از سایت", + "mycourses": "درس‌های من", + "website": "پایگاه اینترنتی" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/fi.json b/src/core/mainmenu/lang/fi.json new file mode 100644 index 000000000..9842996fb --- /dev/null +++ b/src/core/mainmenu/lang/fi.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Mobiilisovelluksen asetukset", + "changesite": "Vaihda sivustoa", + "help": "Ohje", + "logout": "Kirjaudu ulos", + "mycourses": "Omat kurssini", + "togglemenu": "Valikko päälle/pois", + "website": "Www-sivusto" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/fr.json b/src/core/mainmenu/lang/fr.json new file mode 100644 index 000000000..665a741dd --- /dev/null +++ b/src/core/mainmenu/lang/fr.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Réglages de l'app", + "changesite": "Changer de plateforme", + "help": "Aide", + "logout": "Déconnexion", + "mycourses": "Mes cours", + "togglemenu": "Menu", + "website": "Site web" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/he.json b/src/core/mainmenu/lang/he.json new file mode 100644 index 000000000..df2620a01 --- /dev/null +++ b/src/core/mainmenu/lang/he.json @@ -0,0 +1,9 @@ +{ + "appsettings": "הגדרות יישומון", + "changesite": "התנתק", + "help": "עזרה", + "logout": "התנתקות", + "mycourses": "הקורסים שלי", + "togglemenu": "החלפת מצב תפריט", + "website": "אתר אינטרנט" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/hr.json b/src/core/mainmenu/lang/hr.json new file mode 100644 index 000000000..e9d73415c --- /dev/null +++ b/src/core/mainmenu/lang/hr.json @@ -0,0 +1,8 @@ +{ + "appsettings": "Postavke aplikacije", + "changesite": "Promijeni poslužitelj", + "help": "Pomoć", + "logout": "Odjava", + "mycourses": "Moji e-kolegiji", + "website": "Web" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/hu.json b/src/core/mainmenu/lang/hu.json new file mode 100644 index 000000000..c7739b3a4 --- /dev/null +++ b/src/core/mainmenu/lang/hu.json @@ -0,0 +1,7 @@ +{ + "changesite": "Kilépés", + "help": "Súgó", + "logout": "Kilépés", + "mycourses": "Kurzusaim", + "website": "Weboldal" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/it.json b/src/core/mainmenu/lang/it.json new file mode 100644 index 000000000..9e368b1ef --- /dev/null +++ b/src/core/mainmenu/lang/it.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Impostazioni app", + "changesite": "Cambia sito", + "help": "Aiuto", + "logout": "Esci", + "mycourses": "I miei corsi", + "togglemenu": "Attiva/disattiva menu", + "website": "Sito web" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/ja.json b/src/core/mainmenu/lang/ja.json new file mode 100644 index 000000000..c91ac1393 --- /dev/null +++ b/src/core/mainmenu/lang/ja.json @@ -0,0 +1,8 @@ +{ + "appsettings": "アプリ設定", + "changesite": "ログアウト", + "help": "ヘルプ", + "logout": "ログアウト", + "mycourses": "マイコース", + "website": "ウェブサイト" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/lt.json b/src/core/mainmenu/lang/lt.json new file mode 100644 index 000000000..4f3f66ea9 --- /dev/null +++ b/src/core/mainmenu/lang/lt.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Programėlės nustatymai", + "changesite": "Pakeisti svetainę", + "help": "Žinynas", + "logout": "Atsijungti", + "mycourses": "Mano kursai", + "togglemenu": "Perjungti", + "website": "Interneto svetainė" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/mr.json b/src/core/mainmenu/lang/mr.json new file mode 100644 index 000000000..9f0dbf261 --- /dev/null +++ b/src/core/mainmenu/lang/mr.json @@ -0,0 +1,9 @@ +{ + "appsettings": "अॅप सेटिंग्ज", + "changesite": "साइट बदला", + "help": "मदत", + "logout": "लॉग-आउट", + "mycourses": "माझे कोर्सेस", + "togglemenu": "मेनू बदला", + "website": "वेबसाइट" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/nl.json b/src/core/mainmenu/lang/nl.json new file mode 100644 index 000000000..7caa7f904 --- /dev/null +++ b/src/core/mainmenu/lang/nl.json @@ -0,0 +1,9 @@ +{ + "appsettings": "App instellingen", + "changesite": "Naar andere site", + "help": "Help", + "logout": "Uitloggen", + "mycourses": "Mijn cursussen", + "togglemenu": "Menu schakelen", + "website": "Website" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/no.json b/src/core/mainmenu/lang/no.json new file mode 100644 index 000000000..e049b9cd8 --- /dev/null +++ b/src/core/mainmenu/lang/no.json @@ -0,0 +1,5 @@ +{ + "help": "Hjelp", + "logout": "Logg ut", + "mycourses": "Mine kurs" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/pl.json b/src/core/mainmenu/lang/pl.json new file mode 100644 index 000000000..db5b40a15 --- /dev/null +++ b/src/core/mainmenu/lang/pl.json @@ -0,0 +1,7 @@ +{ + "changesite": "Wyloguj", + "help": "Pomoc", + "logout": "Wyloguj", + "mycourses": "Moje kursy", + "website": "Witryna" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/pt-br.json b/src/core/mainmenu/lang/pt-br.json new file mode 100644 index 000000000..fd3d93a17 --- /dev/null +++ b/src/core/mainmenu/lang/pt-br.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Configurações do aplicativo", + "changesite": "Mudar site", + "help": "Ajuda", + "logout": "Sair", + "mycourses": "Meus cursos", + "togglemenu": "Alternar menu", + "website": "Site" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/pt.json b/src/core/mainmenu/lang/pt.json new file mode 100644 index 000000000..479ba8e4f --- /dev/null +++ b/src/core/mainmenu/lang/pt.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Configurações da aplicação", + "changesite": "Mudar de site", + "help": "Ajuda", + "logout": "Sair", + "mycourses": "As minhas disciplinas", + "togglemenu": "Alternar menu", + "website": "Site" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/ro.json b/src/core/mainmenu/lang/ro.json new file mode 100644 index 000000000..1c5f17d9e --- /dev/null +++ b/src/core/mainmenu/lang/ro.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Setările aplicației", + "changesite": "Schimbați siteul", + "help": "Ajutor", + "logout": "Ieşire", + "mycourses": "Cursurile mele", + "togglemenu": "Meniul pentru comutare", + "website": "Website" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/ru.json b/src/core/mainmenu/lang/ru.json new file mode 100644 index 000000000..541a10d32 --- /dev/null +++ b/src/core/mainmenu/lang/ru.json @@ -0,0 +1,8 @@ +{ + "appsettings": "Настройки приложения", + "changesite": "Выход", + "help": "Справка", + "logout": "Выход", + "mycourses": "Мои курсы", + "website": "Сайт" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/sr-cr.json b/src/core/mainmenu/lang/sr-cr.json new file mode 100644 index 000000000..8323e0aa5 --- /dev/null +++ b/src/core/mainmenu/lang/sr-cr.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Подешавања апликације", + "changesite": "Промени сајт", + "help": "Помоћ", + "logout": "Одјава", + "mycourses": "Моји курсеви", + "togglemenu": "Укључи/искључи мени", + "website": "Веб сајт" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/sr-lt.json b/src/core/mainmenu/lang/sr-lt.json new file mode 100644 index 000000000..aa6e18a37 --- /dev/null +++ b/src/core/mainmenu/lang/sr-lt.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Podešavanja aplikacije", + "changesite": "Promeni sajt", + "help": "Pomoć", + "logout": "Odjava", + "mycourses": "Moji kursevi", + "togglemenu": "Uključi/isključi meni", + "website": "Veb sajt" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/sv.json b/src/core/mainmenu/lang/sv.json new file mode 100644 index 000000000..c1787a309 --- /dev/null +++ b/src/core/mainmenu/lang/sv.json @@ -0,0 +1,8 @@ +{ + "appsettings": "App inställningar", + "changesite": "Byt webbsida", + "help": "Hjälp", + "logout": "Logga ut", + "mycourses": "Mina kurser", + "website": "Webbsida" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/tr.json b/src/core/mainmenu/lang/tr.json new file mode 100644 index 000000000..ace500a4d --- /dev/null +++ b/src/core/mainmenu/lang/tr.json @@ -0,0 +1,7 @@ +{ + "changesite": "Çıkış", + "help": "Yardım", + "logout": "Çıkış yap", + "mycourses": "Derslerim", + "website": "Websitesi" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/uk.json b/src/core/mainmenu/lang/uk.json new file mode 100644 index 000000000..21328fec9 --- /dev/null +++ b/src/core/mainmenu/lang/uk.json @@ -0,0 +1,9 @@ +{ + "appsettings": "Налаштування додатку", + "changesite": "Змінити сайт", + "help": "Допомога", + "logout": "Вихід", + "mycourses": "Мої курси", + "togglemenu": "Перемикання меню", + "website": "Веб-сайт" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/zh-cn.json b/src/core/mainmenu/lang/zh-cn.json new file mode 100644 index 000000000..ea6cd6e91 --- /dev/null +++ b/src/core/mainmenu/lang/zh-cn.json @@ -0,0 +1,7 @@ +{ + "changesite": "注销", + "help": "帮助", + "logout": "注销", + "mycourses": "我的课程", + "website": "网站" +} \ No newline at end of file diff --git a/src/core/mainmenu/lang/zh-tw.json b/src/core/mainmenu/lang/zh-tw.json new file mode 100644 index 000000000..412f26164 --- /dev/null +++ b/src/core/mainmenu/lang/zh-tw.json @@ -0,0 +1,9 @@ +{ + "appsettings": "應用程式設定", + "changesite": "更換網站", + "help": "協助", + "logout": "更換網站", + "mycourses": "我的課程", + "togglemenu": "切換功能選單", + "website": "網站" +} \ No newline at end of file diff --git a/src/core/mainmenu/mainmenu.module.ts b/src/core/mainmenu/mainmenu.module.ts new file mode 100644 index 000000000..7cee1594c --- /dev/null +++ b/src/core/mainmenu/mainmenu.module.ts @@ -0,0 +1,27 @@ +// (C) Copyright 2015 Martin Dougiamas +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +import { NgModule } from '@angular/core'; +import { CoreMainMenuDelegate } from './providers/delegate'; + +@NgModule({ + declarations: [ + ], + imports: [ + ], + providers: [ + CoreMainMenuDelegate, + ] +}) +export class CoreMainMenuModule {} diff --git a/src/core/mainmenu/pages/menu/menu.html b/src/core/mainmenu/pages/menu/menu.html new file mode 100644 index 000000000..ec3f330e1 --- /dev/null +++ b/src/core/mainmenu/pages/menu/menu.html @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/src/core/mainmenu/pages/menu/menu.module.ts b/src/core/mainmenu/pages/menu/menu.module.ts new file mode 100644 index 000000000..2f8f96523 --- /dev/null +++ b/src/core/mainmenu/pages/menu/menu.module.ts @@ -0,0 +1,31 @@ +// (C) Copyright 2015 Martin Dougiamas +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +import { NgModule } from '@angular/core'; +import { IonicPageModule } from 'ionic-angular'; +import { TranslateModule } from '@ngx-translate/core'; +import { CoreMainMenuPage } from './menu'; +import { CoreMainMenuModule } from '../../mainmenu.module'; + +@NgModule({ + declarations: [ + CoreMainMenuPage, + ], + imports: [ + CoreMainMenuModule, + IonicPageModule.forChild(CoreMainMenuPage), + TranslateModule.forChild() + ], +}) +export class CoreMainMenuPageModule {} diff --git a/src/core/mainmenu/pages/menu/menu.scss b/src/core/mainmenu/pages/menu/menu.scss new file mode 100644 index 000000000..87c7bcce9 --- /dev/null +++ b/src/core/mainmenu/pages/menu/menu.scss @@ -0,0 +1,3 @@ +page-core-mainmenu { + +} diff --git a/src/core/mainmenu/pages/menu/menu.ts b/src/core/mainmenu/pages/menu/menu.ts new file mode 100644 index 000000000..8ed726590 --- /dev/null +++ b/src/core/mainmenu/pages/menu/menu.ts @@ -0,0 +1,72 @@ +// (C) Copyright 2015 Martin Dougiamas +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +import { Component, OnDestroy } from '@angular/core'; +import { IonicPage, NavController } from 'ionic-angular'; +import { CoreEventsProvider } from '../../../../providers/events'; +import { CoreSitesProvider } from '../../../../providers/sites'; +import { CoreMainMenuDelegate, CoreMainMenuHandlerData } from '../../providers/delegate'; + +/** + * Page that displays the main menu of the app. + */ +@IonicPage() +@Component({ + selector: 'page-core-mainmenu', + templateUrl: 'menu.html', +}) +export class CoreMainMenuPage implements OnDestroy { + tabs: CoreMainMenuHandlerData[]; + loaded: boolean; + protected subscription; + protected moreTabData = { + page: 'CoreMainMenuMorePage', + title: 'core.more', + icon: 'more' + }; + protected logoutObserver; + + constructor(private menuDelegate: CoreMainMenuDelegate, private sitesProvider: CoreSitesProvider, + private navCtrl: NavController, eventsProvider: CoreEventsProvider) { + + // Go to sites page when user is logged out. + this.logoutObserver = eventsProvider.on(CoreEventsProvider.LOGOUT, () => { + this.navCtrl.setRoot('CoreLoginSitesPage'); + }); + } + + /** + * View loaded. + */ + ionViewDidLoad() { + if (!this.sitesProvider.isLoggedIn()) { + this.navCtrl.setRoot('CoreLoginSitesPage'); + return; + } + + this.subscription = this.menuDelegate.getHandlers().subscribe((handlers) => { + this.tabs = handlers.slice(0, 4); // Get first 4. + this.tabs.push(this.moreTabData); // Add "More" tab. + this.loaded = this.menuDelegate.areHandlersLoaded(); + }); + } + + /** + * Page destroyed. + */ + ngOnDestroy() { + this.subscription && this.subscription.unsubscribe(); + this.logoutObserver && this.logoutObserver.off(); + } +} diff --git a/src/core/mainmenu/providers/delegate.ts b/src/core/mainmenu/providers/delegate.ts new file mode 100644 index 000000000..613d562be --- /dev/null +++ b/src/core/mainmenu/providers/delegate.ts @@ -0,0 +1,202 @@ +// (C) Copyright 2015 Martin Dougiamas +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +import { Injectable } from '@angular/core'; +import { CoreEventsProvider } from '../../../providers/events'; +import { CoreLoggerProvider } from '../../../providers/logger'; +import { CoreSitesProvider } from '../../../providers/sites'; +import { Subject, BehaviorSubject } from 'rxjs'; + +export interface CoreMainMenuHandler { + name: string; // Name of the handler. + priority: number; // The highest priority is displayed first. + isEnabled(): boolean|Promise; // Whether or not the handler is enabled on a site level. + getDisplayData(): CoreMainMenuHandlerData; // Returns the data needed to render the handler. +}; + +export interface CoreMainMenuHandlerData { + page: string; // Name of the page. + title: string; // Title to display in the tab. + icon: string; // Name of the icon to display in the tab. + class?: string; // Class to add to the displayed handler. +}; + +/** + * Service to interact with plugins to be shown in the main menu. Provides functions to register a plugin + * and notify an update in the data. + */ +@Injectable() +export class CoreMainMenuDelegate { + protected logger; + protected handlers: {[s: string]: CoreMainMenuHandler} = {}; + protected enabledHandlers: {[s: string]: CoreMainMenuHandler} = {}; + protected loaded = false; + protected lastUpdateHandlersStart: number; + protected siteHandlers: Subject = new BehaviorSubject([]); + + constructor(logger: CoreLoggerProvider, private sitesProvider: CoreSitesProvider, eventsProvider: CoreEventsProvider) { + this.logger = logger.getInstance('CoreMainMenuDelegate'); + + eventsProvider.on(CoreEventsProvider.LOGIN, this.updateHandlers.bind(this)); + eventsProvider.on(CoreEventsProvider.SITE_UPDATED, this.updateHandlers.bind(this)); + eventsProvider.on(CoreEventsProvider.REMOTE_ADDONS_LOADED, this.updateHandlers.bind(this)); + eventsProvider.on(CoreEventsProvider.LOGOUT, this.clearSiteHandlers.bind(this)); + } + + /** + * Check if handlers are loaded. + * + * @return {boolean} True if handlers are loaded, false otherwise. + */ + areHandlersLoaded() : boolean { + return this.loaded; + } + + /** + * Clear current site handlers. Reserved for core use. + */ + protected clearSiteHandlers() { + this.loaded = false; + this.siteHandlers.next([]); + } + + /** + * Get the handlers for the current site. + * + * @return {Subject} An observable that will receive the handlers. + */ + getHandlers() : Subject { + return this.siteHandlers; + } + + /** + * Check if a time belongs to the last update handlers call. + * This is to handle the cases where updateHandlers don't finish in the same order as they're called. + * + * @param {number} time Time to check. + * @return {boolean} Whether it's the last call. + */ + isLastUpdateCall(time: number) : boolean { + if (!this.lastUpdateHandlersStart) { + return true; + } + return time == this.lastUpdateHandlersStart; + } + + /** + * Register a handler. + * + * @param {CoreInitHandler} handler The handler to register. + * @return {boolean} True if registered successfully, false otherwise. + */ + registerHandler(handler: CoreMainMenuHandler) : boolean { + if (typeof this.handlers[handler.name] !== 'undefined') { + this.logger.log(`Addon 'handler.name' already registered`); + return false; + } + this.logger.log(`Registered addon 'handler.name'`); + this.handlers[handler.name] = handler; + return true; + } + + /** + * Update the handler for the current site. + * + * @param {CoreInitHandler} handler The handler to check. + * @param {number} time Time this update process started. + * @return {Promise} Resolved when done. + */ + protected updateHandler(handler: CoreMainMenuHandler, time: number) : Promise { + let promise, + siteId = this.sitesProvider.getCurrentSiteId(), + currentSite = this.sitesProvider.getCurrentSite(); + + if (!this.sitesProvider.isLoggedIn()) { + promise = Promise.reject(null); + } else if (currentSite.isFeatureDisabled('$mmSideMenuDelegate_' + handler.name)) { + promise = Promise.resolve(false); + } else { + promise = Promise.resolve(handler.isEnabled()); + } + + // Checks if the handler is enabled. + return promise.catch(() => { + return false; + }).then((enabled: boolean) => { + // Verify that this call is the last one that was started. + // Check that site hasn't changed since the check started. + if (this.isLastUpdateCall(time) && this.sitesProvider.getCurrentSiteId() === siteId) { + if (enabled) { + this.enabledHandlers[handler.name] = handler; + } else { + delete this.enabledHandlers[handler.name]; + } + } + }); + } + + /** + * Update the handlers for the current site. + * + * @return {Promise} Resolved when done. + */ + protected updateHandlers() : Promise { + let promises = [], + now = Date.now(); + + this.logger.debug('Updating handlers for current site.'); + + this.lastUpdateHandlersStart = now; + + // Loop over all the handlers. + for (let name in this.handlers) { + promises.push(this.updateHandler(this.handlers[name], now)); + } + + return Promise.all(promises).then(() => { + return true; + }, () => { + // Never reject. + return true; + }).then(() => { + // Verify that this call is the last one that was started. + if (this.isLastUpdateCall(now)) { + let handlersData: any[] = []; + + for (let name in this.enabledHandlers) { + let handler = this.enabledHandlers[name], + data = handler.getDisplayData(); + + handlersData.push({ + data: data, + priority: handler.priority + }); + } + + // Sort them by priority. + handlersData.sort((a, b) => { + return b.priority - a.priority; + }); + + // Return only the display data. + let displayData = handlersData.map((item) => { + return item.data; + }); + + this.loaded = true; + this.siteHandlers.next(displayData); + } + }); + } +} diff --git a/src/lang/en.json b/src/lang/en.json index 3b9f8ba52..64a2104f4 100644 --- a/src/lang/en.json +++ b/src/lang/en.json @@ -133,6 +133,7 @@ "mod_url": "URL", "mod_wiki": "Wiki", "mod_workshop": "Workshop", + "more": "More", "mygroups": "My groups", "name": "Name", "nograde": "No grade",