From 4af2e0ff07b460c47454f79039838906bfa59524 Mon Sep 17 00:00:00 2001 From: Omid Rad Date: Tue, 19 Mar 2024 09:07:13 +0100 Subject: [PATCH] Support Gnome 46 --- PersianCalendar@oxygenws.com/Calendar.js | 62 +++++----- PersianCalendar@oxygenws.com/extension.js | 110 ++++++++++-------- .../fa_IR/LC_MESSAGES/persian-calendar.po | 2 +- .../locale/persian-calendar.pot | 2 +- PersianCalendar@oxygenws.com/metadata.json | 2 +- 5 files changed, 95 insertions(+), 83 deletions(-) diff --git a/PersianCalendar@oxygenws.com/Calendar.js b/PersianCalendar@oxygenws.com/Calendar.js index b4bdec6..37a93a9 100644 --- a/PersianCalendar@oxygenws.com/Calendar.js +++ b/PersianCalendar@oxygenws.com/Calendar.js @@ -13,7 +13,7 @@ export class Calendar { this._gettext = gettext; this._locale = locale; this._events = events; - + this.phrases = { weekdayOne: [this._gettext.p__('Sat', 'S'), this._gettext.p__('Sun', 'S'), this._gettext.p__('Mon', 'M'), this._gettext.p__('Tue', 'T'), this._gettext.p__('Wed', 'W'), this._gettext.p__('Thu', 'T'), this._gettext.p__('Fri', 'F')], @@ -72,8 +72,8 @@ export class Calendar { dow = 0; } - let find = ['%Y', '%y', '%MM', '%mm', '%M', '%m', '%D', '%d', '%WW', '%ww', '%w']; - let replace = [ + const find = ['%Y', '%y', '%MM', '%mm', '%M', '%m', '%D', '%d', '%WW', '%ww', '%w']; + const replace = [ year, `${year}`.slice(-2), this.phrases[calendar].monthLong[month - 1], @@ -103,7 +103,7 @@ export class Calendar { this.actor.layout_manager.attach(this._topBox, 0, 0, 7, 1); let icon, nextYearButton, prevYearButton, nextMonthButton, prevMonthButton; - let style = 'pager-button'; + const style = 'pager-button'; icon = new St.Icon({icon_name: this._locale.isRtl() ? 'go-first-symbolic' : 'go-last-symbolic'}); nextYearButton = new St.Button({style_class: style, child: icon}); nextYearButton.connect('clicked', this._onNextYearButtonClicked.bind(this)); @@ -148,7 +148,7 @@ export class Calendar { // Add weekday labels... for (let i = 0; i < 7; i++) { - let label = new St.Label({ + const label = new St.Label({ style_class: 'calendar-day calendar-day-heading pcalendar-weekday', text: this.phrases.weekdayOne[i], }); @@ -161,7 +161,7 @@ export class Calendar { } _setFont(el) { - // let font_desc = Pango.FontDescription.from_string(this._schema.get_string('font')); + // const font_desc = Pango.FontDescription.from_string(this._schema.get_string('font')); // // if (this._schema.get_boolean('custom-font')) { // el.clutter_text.set_font_description(font_desc); @@ -171,7 +171,7 @@ export class Calendar { } _modifyFont(el) { - // let font_desc = Pango.FontDescription.from_string(this._schema.get_string('font')); + // const font_desc = Pango.FontDescription.from_string(this._schema.get_string('font')); // // if (this._schema.get_boolean('custom-font')) { // el.modify_font(font_desc); @@ -179,8 +179,8 @@ export class Calendar { // el.modify_font(null); // } - // let font_desc = Pango.FontDescription.from_string(this._schema.get_string('font')); - // let pc = el.get_pango_context(); + // cosnt font_desc = Pango.FontDescription.from_string(this._schema.get_string('font')); + // const pc = el.get_pango_context(); // // pc.set_font_description(font_desc); // pc.changed(); @@ -202,8 +202,8 @@ export class Calendar { } _onPrevMonthButtonClicked() { - let newDate = this._selectedDate; - let oldMonth = newDate.month; + const newDate = this._selectedDate; + const oldMonth = newDate.month; if (oldMonth === 1) { newDate.month = 12; newDate.year--; @@ -215,8 +215,8 @@ export class Calendar { } _onNextMonthButtonClicked() { - let newDate = this._selectedDate; - let oldMonth = newDate.month; + const newDate = this._selectedDate; + const oldMonth = newDate.month; if (oldMonth === 12) { newDate.month = 1; newDate.year++; @@ -228,14 +228,14 @@ export class Calendar { } _onPrevYearButtonClicked() { - let newDate = this._selectedDate; + const newDate = this._selectedDate; newDate.year--; this.setDate(newDate); } _onNextYearButtonClicked() { - let newDate = this._selectedDate; + const newDate = this._selectedDate; newDate.year++; this.setDate(newDate); @@ -261,7 +261,7 @@ export class Calendar { )); // Remove everything but the topBox and the weekday labels - let children = this.actor.get_children(); + const children = this.actor.get_children(); for (let i = this._firstDayIndex; i < children.length; i++) { children[i].destroy(); } @@ -270,7 +270,7 @@ export class Calendar { let iter = this._selectedDate; iter = PersianDate.toGregorian(iter.year, iter.month, 1); iter = new Date(iter.year, iter.month - 1, iter.day); - let daysToWeekStart = (7 + iter.getDay() - this._weekStart) % 7; + const daysToWeekStart = (7 + iter.getDay() - this._weekStart) % 7; iter.setDate(iter.getDate() - daysToWeekStart); let row = 2; @@ -278,13 +278,13 @@ export class Calendar { /* eslint no-constant-condition: ["error", { "checkLoops": false }] */ while (true) { - let p_iter = PersianDate.fromGregorian( + const p_iter = PersianDate.fromGregorian( iter.getFullYear(), iter.getMonth() + 1, iter.getDate(), ); - let is_same_month = p_iter.month === this._selectedDate.month; - let button = new St.Button({label: this._str.transDigits(p_iter.day)}); + const is_same_month = p_iter.month === this._selectedDate.month; + const button = new St.Button({label: this._str.transDigits(p_iter.day)}); this._modifyFont(button); button.connect('clicked', () => this.setDate(p_iter)); @@ -347,7 +347,7 @@ export class Calendar { g_selectedDate = new Date(g_selectedDate.year, g_selectedDate.month - 1, g_selectedDate.day); // find hijri date of today - let h_selectedDate = HijriDate.fromGregorian( + const h_selectedDate = HijriDate.fromGregorian( g_selectedDate.getFullYear(), g_selectedDate.getMonth() + 1, g_selectedDate.getDate(), @@ -355,30 +355,30 @@ export class Calendar { // add persian date if (this._schema.get_boolean('persian-display')) { - let _datesBox_p = new St.BoxLayout(); + const _datesBox_p = new St.BoxLayout(); this.actor.layout_manager.attach(_datesBox_p, 0, ++row, 7, 1); - let button = this.getPersianDateButton(this._selectedDate, g_selectedDate.getDay()); + const button = this.getPersianDateButton(this._selectedDate, g_selectedDate.getDay()); _datesBox_p.add_child(button); } // add gregorian date if (this._schema.get_boolean('gregorian-display')) { - let _datesBox_g = new St.BoxLayout(); + const _datesBox_g = new St.BoxLayout(); this.actor.layout_manager.attach(_datesBox_g, 0, ++row, 7, 1); - let gDate = { + const gDate = { day: g_selectedDate.getDate(), month: g_selectedDate.getMonth() + 1, year: g_selectedDate.getFullYear(), }; - let button = this.getGregorianDateButton(gDate, g_selectedDate.getDay()); + const button = this.getGregorianDateButton(gDate, g_selectedDate.getDay()); _datesBox_g.add_child(button); } // add hijri date if (this._schema.get_boolean('hijri-display')) { - let _datesBox_h = new St.BoxLayout(); + const _datesBox_h = new St.BoxLayout(); this.actor.layout_manager.attach(_datesBox_h, 0, ++row, 7, 1); - let button = this.getHijriDateButton(h_selectedDate, g_selectedDate.getDay()); + const button = this.getHijriDateButton(h_selectedDate, g_selectedDate.getDay()); _datesBox_h.add_child(button); } @@ -386,9 +386,9 @@ export class Calendar { events = this._events.getEvents(g_selectedDate); if (events[0]) { - let _eventBox = new St.BoxLayout(); + const _eventBox = new St.BoxLayout(); this.actor.layout_manager.attach(_eventBox, 0, ++row, 7, 1); - let bottomLabel = new St.Label({ + const bottomLabel = new St.Label({ text: this._str.transDigits(events[0]), style_class: 'pcalendar-event-label', x_align: Clutter.ActorAlign.FILL, @@ -419,7 +419,7 @@ export class Calendar { } _getDateButton(date, dayOfWeek, calendar) { - let button = new St.Button({ + const button = new St.Button({ label: this.format( this._schema.get_string(`${calendar}-display-format`), date.day, diff --git a/PersianCalendar@oxygenws.com/extension.js b/PersianCalendar@oxygenws.com/extension.js index 1d93885..ffdf56d 100644 --- a/PersianCalendar@oxygenws.com/extension.js +++ b/PersianCalendar@oxygenws.com/extension.js @@ -47,7 +47,7 @@ const PersianCalendar = GObject.registerClass( }); this.hide(); - this.add_actor(this.label); + this.add_child(this.label); // some codes for coloring label if (this._settings.get_boolean('custom-color')) { @@ -86,8 +86,8 @@ const PersianCalendar = GObject.registerClass( this._today = ''; - let vbox = new St.BoxLayout({vertical: true}); - let calendar = new PopupMenu.PopupBaseMenuItem({ + const vbox = new St.BoxLayout({vertical: true}); + const calendar = new PopupMenu.PopupBaseMenuItem({ activate: false, hover: false, can_focus: false, @@ -98,7 +98,7 @@ const PersianCalendar = GObject.registerClass( this.menu._arrowAlignment = 0.5; this._calendar = new Calendar(this._settings, this._str, this._gettext, this._locale, this._events); - vbox.add_actor(this._calendar.actor); + vbox.add_child(this._calendar.actor); this._calendar.actor.add_style_class_name('pcalendar-font'); // ////////////////////////////// @@ -118,7 +118,7 @@ const PersianCalendar = GObject.registerClass( this._generateConverterPart(); // action buttons - let actionButtons = new PopupMenu.PopupBaseMenuItem({ + const actionButtons = new PopupMenu.PopupBaseMenuItem({ reactive: false, can_focus: false, }); @@ -130,7 +130,7 @@ const PersianCalendar = GObject.registerClass( style_class: 'popup-menu-icon calendar-popup-menu-icon', }); - let preferencesIcon = new St.Button({ + const preferencesIcon = new St.Button({ child: icon, style_class: 'button system-menu-action calendar-preferences-button', reactive: true, @@ -149,7 +149,7 @@ const PersianCalendar = GObject.registerClass( style_class: 'popup-menu-icon calendar-popup-menu-icon', }); - let nowruzIcon = new St.Button({ + const nowruzIcon = new St.Button({ child: icon, style_class: 'button system-menu-action calendar-preferences-button', reactive: true, @@ -172,7 +172,7 @@ const PersianCalendar = GObject.registerClass( } _onFontChangeForIcon() { - // let font_desc = Pango.FontDescription.from_string(this._settings.get_string('font')); + // const font_desc = Pango.FontDescription.from_string(this._settings.get_string('font')); // font_desc = Pango.FontDescription.from_string(font_desc.get_family()); // // if (this._settings.get_boolean('custom-font')) { @@ -183,8 +183,8 @@ const PersianCalendar = GObject.registerClass( } _onFontChangeForCalendar() { - // let font_desc = Pango.FontDescription.from_string(this._settings.get_string('font')); - // let pc = this._calendar.actor.get_pango_context(); + // const font_desc = Pango.FontDescription.from_string(this._settings.get_string('font')); + // const pc = this._calendar.actor.get_pango_context(); // // global.log("PersianCalendar@oxygenws.com22", font_desc.get_family()); // pc.set_font_description(font_desc); @@ -193,7 +193,7 @@ const PersianCalendar = GObject.registerClass( _updateDate(skip_notification, force) { let _date = new Date(); - let _dayOfWeek = _date.getDay(); + const _dayOfWeek = _date.getDay(); // convert to Persian _date = PersianDate.fromGregorian(_date.getFullYear(), _date.getMonth() + 1, _date.getDate()); @@ -208,7 +208,7 @@ const PersianCalendar = GObject.registerClass( // set indicator label and popupmenu // get events of today - let events = this._events.getEvents(new Date()); + const events = this._events.getEvents(new Date()); events[0] = events[0] !== '' ? `\n${events[0]}` : ''; // is holiday? @@ -248,23 +248,23 @@ const PersianCalendar = GObject.registerClass( _generateConverterPart() { // Add date conversion button - let converterMenu = new PopupMenu.PopupSubMenuMenuItem(this._gettext.__('Date conversion')); + const converterMenu = new PopupMenu.PopupSubMenuMenuItem(this._gettext.__('Date conversion')); converterMenu.actor.add_style_class_name('pcalendar-font'); this.menu.addMenuItem(converterMenu); this.converterVbox = new St.BoxLayout({style_class: 'pcalendar-font', vertical: true, x_expand: true}); - let converterSubMenu = new PopupMenu.PopupBaseMenuItem({ + const converterSubMenu = new PopupMenu.PopupBaseMenuItem({ reactive: false, can_focus: false, }); converterSubMenu.actor.add_child(this.converterVbox); converterMenu.menu.addMenuItem(converterSubMenu); - let middleBox = new St.BoxLayout({style_class: 'pcalendar-converter-box', x_expand: true}); + const middleBox = new St.BoxLayout({style_class: 'pcalendar-converter-box', x_expand: true}); this._activeConverter = ConverterTypes.fromPersian; - let fromPersian = new St.Button({ + const fromPersian = new St.Button({ reactive: true, can_focus: true, track_hover: true, @@ -276,7 +276,7 @@ const PersianCalendar = GObject.registerClass( fromPersian.connect('clicked', this._toggleConverter.bind(this)); fromPersian.TypeID = ConverterTypes.fromPersian; - let fromGregorian = new St.Button({ + const fromGregorian = new St.Button({ reactive: true, can_focus: true, track_hover: true, @@ -288,7 +288,7 @@ const PersianCalendar = GObject.registerClass( fromGregorian.connect('clicked', this._toggleConverter.bind(this)); fromGregorian.TypeID = ConverterTypes.fromGregorian; - let fromHijri = new St.Button({ + const fromHijri = new St.Button({ reactive: true, can_focus: true, track_hover: true, @@ -312,7 +312,7 @@ const PersianCalendar = GObject.registerClass( this.converterVbox.add_child(middleBox); - let converterHbox = new St.BoxLayout({style_class: 'pcalendar-converter-box'}); + const converterHbox = new St.BoxLayout({style_class: 'pcalendar-converter-box'}); this.converterYear = new St.Entry({ name: 'year', @@ -360,14 +360,14 @@ const PersianCalendar = GObject.registerClass( _onModifyConverter() { // erase old date - let convertedDatesChildren = this.convertedDatesVbox.get_children(); + const convertedDatesChildren = this.convertedDatesVbox.get_children(); for (let i = 0; i < convertedDatesChildren.length; i++) { convertedDatesChildren[i].destroy(); } - let year = this.converterYear.get_text(); - let month = this.converterMonth.get_text(); - let day = this.converterDay.get_text(); + const year = this.converterYear.get_text(); + const month = this.converterMonth.get_text(); + const day = this.converterDay.get_text(); // check if data is numerical and not empty if (isNaN(day) || isNaN(month) || isNaN(year) || year.length !== 4 || day < 1 || day > 31 || month < 1 || month > 12) { @@ -410,19 +410,19 @@ const PersianCalendar = GObject.registerClass( // add persian date if (pDate) { - let button = this._calendar.getPersianDateButton(pDate, dayOfWeek); + const button = this._calendar.getPersianDateButton(pDate, dayOfWeek); this.convertedDatesVbox.add_child(button); } // add gregorian date if (gDate) { - let button = this._calendar.getGregorianDateButton(gDate, dayOfWeek); + const button = this._calendar.getGregorianDateButton(gDate, dayOfWeek); this.convertedDatesVbox.add_child(button); } // add hijri date if (hDate) { - let button = this._calendar.getHijriDateButton(hDate, dayOfWeek); + const button = this._calendar.getHijriDateButton(hDate, dayOfWeek); this.convertedDatesVbox.add_child(button); } } @@ -434,11 +434,11 @@ const PersianCalendar = GObject.registerClass( } // first remove active classes then highlight the clicked button - let tabBox = button.get_parent(); - let tabBoxChildren = tabBox.get_children(); + const tabBox = button.get_parent(); + const tabBoxChildren = tabBox.get_children(); for (let i = 0; i < tabBoxChildren.length; i++) { - let tabButton = tabBoxChildren[i]; + const tabButton = tabBoxChildren[i]; tabButton.remove_style_class_name('active'); } @@ -451,14 +451,14 @@ const PersianCalendar = GObject.registerClass( _showNowruzNotification() { /* calculate exact hour/minute/second of the next new year. it calculates with some small differences! */ - let now = new Date(); - let pdate = PersianDate.fromGregorian( + const now = new Date(); + const pdate = PersianDate.fromGregorian( now.getFullYear(), now.getMonth() + 1, now.getDate(), ); - let month_delta = 12 - pdate.month; + const month_delta = 12 - pdate.month; let day_delta, nowruz; if (month_delta >= 6) { day_delta = 31 - pdate.day; @@ -480,26 +480,38 @@ const PersianCalendar = GObject.registerClass( month_delta, ).format(month_delta, day_delta, pdate.year + 1); } - this.notify(this._str.transDigits(nowruz)); + this.nowruz_notify(this._str.transDigits(nowruz)); } else if (day_delta !== 0) { nowruz = this._gettext.n__( '%d day left to Nowruz %d', '%d days left to Nowruz %d', day_delta, ).format(day_delta, pdate.year + 1); - this.notify(this._str.transDigits(nowruz)); + this.nowruz_notify(this._str.transDigits(nowruz)); } else { - this.notify(this._gettext.__('Happy New Year')); + this.nowruz_notify(this._gettext.__('Happy New Year')); } } - notify(msg, details) { - let source = new MessageTray.SystemNotificationSource(); - let messageTray = new MessageTray.MessageTray(); - messageTray.add(source); - let notification = new MessageTray.Notification(source, msg, details); - notification.setTransient(true); - source.showNotification(notification); + nowruz_notify(title) { + this.notify(title, undefined, 'emblem-favorite-symbolic'); + } + + notify(title, body, iconName) { + const source = new MessageTray.getSystemSource(); + const params = { + source, + title, + isTransient: true, + }; + if (body) { + params.body = body; + } + const notification = new MessageTray.Notification(params); + if (iconName) { + notification.set({iconName}); + } + source.addNotification(notification); } }); @@ -514,7 +526,7 @@ export default class PersianCalendarExtension extends Extension { () => this.openPreferences() ); - let positions = ['left', 'center', 'right']; + const positions = ['left', 'center', 'right']; Main.panel.addToStatusArea( 'persian_calendar', @@ -542,18 +554,18 @@ export default class PersianCalendarExtension extends Extension { } install_fonts() { - let homePath = GLib.get_home_dir(); - let dst = Gio.file_new_for_path(`${homePath}/.local/share/fonts/pcalendarFonts/`); + const homePath = GLib.get_home_dir(); + const dst = Gio.file_new_for_path(`${homePath}/.local/share/fonts/pcalendarFonts/`); if (!dst.query_exists(null)) { - let src = Gio.file_new_for_path(`${this.path}/fonts`); + const src = Gio.file_new_for_path(`${this.path}/fonts`); file.copyDir(src, dst); } } uninstall_fonts() { - let homePath = GLib.get_home_dir(); - let isLocked = Main.sessionMode.currentMode === 'unlock-dialog'; - let dir = Gio.file_new_for_path(`${homePath}/.local/share/fonts/pcalendarFonts/`); + const homePath = GLib.get_home_dir(); + const isLocked = Main.sessionMode.currentMode === 'unlock-dialog'; + const dir = Gio.file_new_for_path(`${homePath}/.local/share/fonts/pcalendarFonts/`); if (dir.query_exists(null) && !isLocked) { file.deleteDir(dir); } diff --git a/PersianCalendar@oxygenws.com/locale/fa_IR/LC_MESSAGES/persian-calendar.po b/PersianCalendar@oxygenws.com/locale/fa_IR/LC_MESSAGES/persian-calendar.po index 84af4a6..7a65f15 100644 --- a/PersianCalendar@oxygenws.com/locale/fa_IR/LC_MESSAGES/persian-calendar.po +++ b/PersianCalendar@oxygenws.com/locale/fa_IR/LC_MESSAGES/persian-calendar.po @@ -496,7 +496,7 @@ msgstr "گزینه‌های ابزارک سینی" #: PersianCalendar@oxygenws.com/prefs.js:48 msgid "Startup notification" -msgstr "راه‌اندازی آگاهی" +msgstr "آگاهی در زمان راه‌اندازی" #: PersianCalendar@oxygenws.com/prefs.js:58 #: PersianCalendar@oxygenws.com/prefs.js:64 diff --git a/PersianCalendar@oxygenws.com/locale/persian-calendar.pot b/PersianCalendar@oxygenws.com/locale/persian-calendar.pot index 0016da6..bfd72c3 100644 --- a/PersianCalendar@oxygenws.com/locale/persian-calendar.pot +++ b/PersianCalendar@oxygenws.com/locale/persian-calendar.pot @@ -8,7 +8,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2023-09-22 12:32+0200\n" +"POT-Creation-Date: 2024-03-19 09:01+0100\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" diff --git a/PersianCalendar@oxygenws.com/metadata.json b/PersianCalendar@oxygenws.com/metadata.json index 7164e86..d374bce 100644 --- a/PersianCalendar@oxygenws.com/metadata.json +++ b/PersianCalendar@oxygenws.com/metadata.json @@ -5,7 +5,7 @@ "name": "Persian Calendar", "original-authors": "Omid Mottaghi Rad", "shell-version": [ - "45" + "46", ], "url": "https://github.com/omid/Persian-Calendar-for-Gnome-Shell", "uuid": "PersianCalendar@oxygenws.com",