Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

More profile migrations #994

Merged
Show file tree
Hide file tree
Changes from 11 commits
Commits
Show all changes
108 commits
Select commit Hold shift + click to select a range
2cab1ed
switched collect and sync lists over to react
Jun 13, 2023
ba5406e
inserted a placeholding div control-list-item
Jun 14, 2023
2ad296c
patch from Jack
Jun 14, 2023
dc1d661
Merge branch 'e-mission:framework_migration_prep' into framework_migr…
Abby-Wheelis Jun 15, 2023
89fadc7
added keys to rows
Jun 16, 2023
c40c9bb
removal of non-relevant code
Jun 16, 2023
af44bf0
replacing hard coded strings
Jun 16, 2023
f558103
start at storing data in better place
Jun 16, 2023
e8bb3d6
spelling
Jun 16, 2023
d8a12aa
starting to work with other rows of profile
Jun 16, 2023
5b20f9f
setting up issue in using key as parameter
Jun 16, 2023
0a629fa
fixing strings
Abby-Wheelis Jun 17, 2023
5db9dd8
text working on sample list item
Jun 20, 2023
337816c
carry data storage change through
Abby-Wheelis Jun 22, 2023
aa547f8
polishing up - removing print statements, altering log
Jun 22, 2023
11de879
update comments, eliminate changes not a part of this PR
Jun 22, 2023
399ea7a
Merge branch 'e-mission:master' into More-Profile-Migrations
Abby-Wheelis Jun 22, 2023
2ddfab5
action parameters for setting rows - some work
Jun 22, 2023
0e2a8f6
Merge branch 'framework_migration_prep' into More-Profile-Migrations
Jun 22, 2023
90eda2b
comments and spacing
Jun 22, 2023
f1373ec
more row migrations
Jun 22, 2023
10f571c
rough draft - two rows unconverted
Jun 23, 2023
0f239b0
fixing strings - i18n
Jun 23, 2023
8a5e546
enabling icons - copy Jack's related commit
Jun 23, 2023
ffab0df
got icons in
Jun 23, 2023
cad1034
tidy code - still ways to go
Jun 23, 2023
b6b1fc6
combine logout and copy (eliminate copy)
Jun 23, 2023
e8b7b19
convert to use of IconButtons
Jun 26, 2023
ebeca54
introduce toggle switches
Jun 26, 2023
813c4f5
experiment with list accordian
Jun 26, 2023
4553eb7
use of .map for creating the collapsing list!
Jun 26, 2023
2934b51
both drop-downs converted to ExpandMenu components
Jun 26, 2023
ddff054
profile settings component draft
Jun 27, 2023
803f782
profile settings in general settings
Jun 27, 2023
757936c
first set settings now in ProfileSettingsComponent
Jun 27, 2023
b4c70b3
different method of passing info to Profile Settings
Jun 27, 2023
df5da35
introduce Demographics Setting Row
Jun 27, 2023
a9043a2
rough sketch everything in ProfileSettings
Jun 28, 2023
e0f9983
more of migration to ProfileSettings component
Jun 28, 2023
7bc97b7
adding a value in the scope for the accuracy setting
Jun 28, 2023
f125321
Merge branch 'framework_migration_prep' into framework_migration_prep
Abby-Wheelis Jun 28, 2023
a3097ac
adding additional argument to angularize call
Jun 28, 2023
aa027ad
cleaned up irrelivant codes and comments
Jun 28, 2023
ffd2bc2
fixing merge conflicts
Jun 28, 2023
cf2871e
Merge pull request #1 from Abby-Wheelis/framework_migration_prep
Abby-Wheelis Jun 28, 2023
b612292
Revert "fixing merge conflicts"
Jun 28, 2023
51c0697
extra param in call to angularize func
Jun 28, 2023
60eb532
optional chaining with settings object
Jun 28, 2023
12f462c
styling for Setting Row
Jun 28, 2023
af58485
working with data flow - settings object
Jun 28, 2023
e106102
styling ExpandMenu
Jun 29, 2023
44bc1be
comment out old code
Jun 29, 2023
3eae605
work with the toggle
Jun 29, 2023
83443ed
begin general-settings to ProfileSettings move
Jun 29, 2023
ff4e490
made rows taller - more white space
Jun 29, 2023
2bf64d2
low accuracy toggle functions not working
Jun 29, 2023
20d29f4
make userData conditional
Jun 29, 2023
bfc6355
dialog menus - replacing action sheets
Jul 5, 2023
dfda0f1
migrating action sheets
Jul 5, 2023
ac73e43
action sheet migrations -- unresolved error
Jul 5, 2023
f2467fa
switched portal out for modal
Jul 6, 2023
f685472
address errors in accuracy toggle
Jul 6, 2023
532f56a
organizing code
Jul 6, 2023
7237343
make whole row clickable
Jul 6, 2023
ca4bd2d
migrate share method
Jul 6, 2023
e6ed67a
working on platform detection
Jul 6, 2023
eb3de5d
introduction of useEffect for keeping up with switches
Jul 6, 2023
3e1940b
Merge pull request #2 from e-mission/framework_migration_prep
Abby-Wheelis Jul 6, 2023
6e3562e
Merge branch 'framework_migration_prep' into More-Profile-Migrations
Jul 6, 2023
161a63c
Merge remote-tracking branch 'upstream/framework_migration_prep' into…
Jul 7, 2023
4a5f24a
Merge remote-tracking branch 'upstream/framework_migration_prep' into…
Jul 11, 2023
d2966a1
patch back over to reliance on ProfileSettings rather than html
Jul 12, 2023
ab1e6a4
conditional showing of log uploads
Jul 12, 2023
3b123e8
formatting modals with elevation
Jul 12, 2023
0bdd36c
migrated show OpCode!
Jul 12, 2023
e8faa6f
create alertbar to use instead of ionic popups
Jul 12, 2023
810a293
SettingRow: prevent duplicate action() call
JGreenlee Jul 14, 2023
ba0c101
ProfileSettings: track collectSettings w/ useState
JGreenlee Jul 14, 2023
8d76706
general-settings: remove $scope.settings.collect
JGreenlee Jul 14, 2023
bfac9c8
profile settings: tweak styling
JGreenlee Jul 14, 2023
32b4254
ProfileSettings: rename variable 'mainControlEl'
JGreenlee Jul 14, 2023
19fa99f
remove unused props from <profile-settings>
JGreenlee Jul 14, 2023
c75d732
fix userData dropdown
Jul 14, 2023
f7da968
remove unused imports
Jul 14, 2023
26fc5c3
fix qrSharing
Jul 14, 2023
d9afec8
removal of converted code
Jul 14, 2023
3f86035
formatting opcode popup
Jul 14, 2023
5ae257b
convert forceState
Jul 14, 2023
1b05012
formatting popups
Jul 14, 2023
78620af
formatting
Jul 14, 2023
3bfa277
migrate notificationSettings
Jul 17, 2023
3d2c9a9
add react native paper dates for reminder time
Jul 17, 2023
ac2d936
formatting TimePickerModal
Jul 17, 2023
9a639ca
cleaning up code
Jul 17, 2023
04d39b6
Merge pull request #5 from Abby-Wheelis/profile-migration-fixes
Abby-Wheelis Jul 17, 2023
43a7ef8
remove old time picker
Jul 18, 2023
cae522a
formatting profile
Jul 18, 2023
4c9f22e
remove no longer needed angularize calls
Jul 18, 2023
ab00bb7
update styles for titles
Jul 18, 2023
d415679
remove unused modules
Jul 19, 2023
0bcd303
fix notification schedule
Jul 19, 2023
6764359
leverage promise on initial load
Jul 19, 2023
017e703
make ReminderTime conditionally visible
Jul 20, 2023
2aee6ae
conditionally show schedule
Jul 20, 2023
7d51924
refactor fetching notifs to ensure scheduled first
Jul 20, 2023
c2c44ff
cleaning up code
Jul 20, 2023
fdf8907
remove .then()
Jul 20, 2023
3907088
Merge remote-tracking branch 'upstream/framework_migration_prep' into…
Aug 2, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion www/i18n/en.json
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,9 @@
"button-accept": "I accept",
"view-qrc": "My OPcode",
"app-version": "App Version",
"reminders-time-of-day": "Time of Day for Reminders ({{time}})"
"reminders-time-of-day": "Time of Day for Reminders ({{time}})",
"upcoming-notifications": "Upcoming Notifications",
"dummy-notification" : "Dummy Notification in 5 Seconds"
},

"general-settings":{
Expand Down
38 changes: 38 additions & 0 deletions www/js/control/ControlDataTable.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
import React from "react";
import { DataTable } from 'react-native-paper';
import { angularize } from "../angular-react-helper";
import { array } from "prop-types";

// Note the camelCase to dash-case conventions when translating to .html files!
// val with explicit call toString() to resolve bool values not showing
const ControlDataTable = ({ controlData }) => {
console.log("Printing data trying to tabulate", controlData); //notif data is not here!
return (
//rows require unique keys!
<DataTable style={styles.table}>
{controlData.map((e) =>
<DataTable.Row key={e.key}>
<DataTable.Cell>{e.key}</DataTable.Cell>
<DataTable.Cell>{e.val.toString()}</DataTable.Cell>
</DataTable.Row>
)}
</DataTable>
);
};
const styles = {
table: {
marginLeft: 10,
borderWidth: 1,
borderColor: 'rgba(0,0,0,0.25)',
borderLeftWidth: 15,
borderLeftColor: 'rgba(0,0,0,0.25)',
}
}
ControlDataTable.propTypes = {
controlData: array
}

// need call to angularize to let the React and Angular co-mingle
//second argument is "module path" - can access later as ControlDataTable.module
angularize(ControlDataTable, 'emission.main.control.dataTable');
export default ControlDataTable;
50 changes: 50 additions & 0 deletions www/js/control/SettingRow.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
import React from "react";
import { angularize } from "../angular-react-helper";
import { Text } from 'react-native-paper';
import { useTranslation } from "react-i18next";
import { string, func, object} from "prop-types";

/*
biggest struggle here is how to pass i18n keys as parameters (or strings in general)
*/

const SettingRow = ({textKey, iconName}) => {
const { t } = useTranslation(); //this accesses the translations
console.log("row created!!!!!", "translate hard-code" + t('general-settings.are-you-sure') + "translate via param" + t(textKey)+ " and the icon (plain string) " + iconName);
Abby-Wheelis marked this conversation as resolved.
Show resolved Hide resolved
//from the above print statement the textKey is "0" and iconName is "undefined" but the hard-coded translation key works great!
return (
<Text variant="headlineSmall">
{"translated text" + t(textKey)}
</Text>
);
};
SettingRow.propTypes = {
textKey: string,
iconName: string
}

/*
tinkered with the idea of a mapped solution, but didn't get any further
*/

// const dummyData = [{textKey: "control.view-privacy", actionFcn:"viewPrivacyPolicy($event)", iconName: "eye"}]

// const SettingList = ({settingParams}) => {
// <List>
// {settingParams.map((setting) =>
// {
// return (<SettingRow
// textKey={setting.textKey}
// actionFcn={setting.actionFcn}
// iconName={setting.iconName}>
// </SettingRow>);
// })
// }
// </List>
// };
// SettingList.propTypes = {
// settingParams: array
// }

angularize(SettingRow, 'emission.main.control.settingRow');
export default SettingRow;
11 changes: 10 additions & 1 deletion www/js/control/general-settings.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@

import angular from 'angular';
import QrCode from './QrCode';
import ControlDataTable from './ControlDataTable';
import SettingRow from './SettingRow';

angular.module('emission.main.control',['emission.services',
'emission.i18n.utils',
Expand All @@ -19,7 +21,9 @@ angular.module('emission.main.control',['emission.services',
'emission.survey.enketo.demographics',
'emission.plugin.logger',
'emission.config.dynamic',
QrCode.module])
QrCode.module,
ControlDataTable.module,
SettingRow.module])

.controller('ControlCtrl', function($scope, $window,
$ionicScrollDelegate, $ionicPlatform,
Expand Down Expand Up @@ -131,6 +135,7 @@ angular.module('emission.main.control',['emission.services',
$scope.settings.notification.prefReminderTime = m.format('LT'); // display in user's locale
if (storeNewVal)
NotificationScheduler.setReminderPrefs({ reminder_time_of_day: m.format('HH:mm') }); // store in HH:mm
$scope.settings.notification.scheduledNotifs = cordova.plugins.notification.local.scheduledNotifs;
}

$scope.fixAppStatus = function() {
Expand Down Expand Up @@ -374,6 +379,10 @@ angular.module('emission.main.control',['emission.services',
NotificationScheduler.getReminderPrefs().then((prefs) => {
$scope.$apply(() => {
const m = moment(prefs.reminder_time_of_day, 'HH:mm');
// defining data used to populate the upcoming display
console.log("data before setting", NotificationScheduler.scheduledNotifs); //data came through here!
$scope.settings.notification.scheduledNotifs = NotificationScheduler.scheduledNotifs;
console.log("data after setting", $scope.settings.notification.scheduledNotifs); //data came through here too!
$scope.settings.notification.prefReminderTimeVal = m.toDate();
$scope.settings.notification.prefReminderTimeOnLoad = prefs.reminder_time_of_day;
$scope.updatePrefReminderTime(false); // update the displayed time
Expand Down
15 changes: 14 additions & 1 deletion www/js/splash/notifScheduler.js
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,20 @@ angular.module('emission.splash.notifscheduler',
if (!notifs?.length)
return Logger.log(`${prefix}, there are no scheduled notifications`);
const time = moment(notifs?.[0].trigger.at).format('HH:mm');
Logger.log(`${prefix}, there are ${notifs.length} scheduled notifications at ${time}`);
//change where this is stored - plugin should be read-only

// cordova.plugins.notification.local.scheduledNotifs = notifs.map((n) => {
scheduler.scheduledNotifs = notifs.map((n) => {
const time = moment(n.trigger.at).format('LT');
const date = moment(n.trigger.at).format('LL');
return {
key: date,
val: time
}
});
//have the list of scheduled show up in this log
Logger.log(`${prefix}, there are ${notifs.length} scheduled notifications at ${time} see list here:`);
console.log("notifications", scheduler.scheduledNotifs);
});
}

Expand Down
34 changes: 16 additions & 18 deletions www/templates/control/main-control.html
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@
<div ng-click="logOut()" id ="switch-user" class="control-icon-button"><i class="icon ion-log-out"></i></div>
</div>
<enketo-demographics-button></enketo-demographics-button>
Abby-Wheelis marked this conversation as resolved.
Show resolved Hide resolved
<!-- here is the html related to my (failing) attempts to convert more of the profile screen -->
<setting-row text-key = "control.view-privacy" icon-name = "eye"></setting-row>
Abby-Wheelis marked this conversation as resolved.
Show resolved Hide resolved

<div class="control-list-item">
<div class="control-list-text" ng-i18next>{{'control.view-privacy'}}</div>
<div ng-click="viewPrivacyPolicy($event)" class="control-icon-button"><i class="ion-eye"></i></div>
Expand Down Expand Up @@ -117,9 +120,15 @@
<div ng-click="checkConsent()" class="control-icon-button"><i class="ion-checkmark-circled"></i></div>
</div>
<div class="control-list-item">
<div class="control-list-text" ng-i18next>Dummy Notification in 5 Seconds</div>
<div class="control-list-text" ng-i18next>{{'control.dummy-notification'}}</div>
<div ng-click="dummyNotification()" class="control-icon-button"><i class="ion-ios-bell"></i></div>
</div>
<!-- notif schedule preview (react component) -->
<div class = "control-list-item">
<div class="control-list-text" ng-i18next>{{'control.upcoming-notifications'}}</div>
</div>
<control-data-table ng-if="settings.notification.prefReminderTime" control-data="settings.notification.scheduledNotifs"></control-data-table>

<div class="control-list-item">
<div class="control-list-text" ng-i18next>{{'control.invalidate-cached-docs'}}</div>
<div ng-click="invalidateCache()" class="control-icon-button"><i class="ion-backspace"></i></div>
Expand All @@ -140,32 +149,21 @@
<div class="control-list-text" ng-i18next>{{'control.check-sensed-data'}}</div>
<div ng-click="showSensed()" class="gray-icon control-icon-button"><i class="ion-ios-arrow-right"></i></div>
</div>
<!-- replaced collection and sync with React DataTable-->
<!-- collection li and data table -->
<div class="control-list-item">
<div class="control-list-text" ng-i18next>{{'control.collection'}}</div>
<div ng-click="editCollectionConfig($event)" class="gray-icon control-icon-button"><i class="ion-edit"></i></div>
</div>
<ion-list>

<ion-item class="row" ng-repeat="entry in settings.collect.show_config">
<div class="col timestamp item-text-wrap control-info">{{entry.key}}</div>
<div class="col detail item-text-wrap control-info"> {{entry.val}}</div>
</ion-item>
</ion-list>
<control-data-table control-data="settings.collect.show_config"></control-data-table>

<!-- sync li and data table -->
<div class="control-list-item">
<div class="control-list-text" ng-i18next>{{'control.sync'}}</div>
<div ng-click="editSyncConfig($event)" class="gray-icon control-icon-button"><i class="ion-edit"></i></div>
</div>
<ion-list>
<ion-item class="row" ng-repeat="entry in settings.sync.show_config">
<div class="col timestamp item-text-wrap control-info">{{entry.key}}</div>
<div class="col detail item-text-wrap control-info"> {{entry.val}}</div>
</ion-item>
<ion-item class="row">
<div class="col timestamp item-text-wrap control-info">host</div>
<div class="col detail item-text-wrap control-info"> {{settings.connect.url}}</div>
</ion-item>
</ion-list>
<control-data-table control-data="settings.sync.show_config"></control-data-table>

<div class="control-list-item">
<div class="control-list-text" ng-i18next>{{'control.app-version'}}</div>
<div class="control-version-number">{{settings.clientAppVer}}</div>
Expand Down