-
Notifications
You must be signed in to change notification settings - Fork 1.7k
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
Contact import improvements #9431
base: master
Are you sure you want to change the base?
Conversation
…ort UI, remove hard coded $local_map
…ist_fields as it relies on rcmail_action_contacts
I moved the Also I completed the second part of my suggestion to remove the hard coded mapping information entirely and use 1 to define the source and destination. |
@@ -201,7 +201,7 @@ class rcmail_action_contacts_index extends rcmail_action | |||
'size' => 40, | |||
'maxlength' => 128, | |||
'label' => 'instantmessenger', | |||
'subtypes' => ['aim', 'icq', 'msn', 'yahoo', 'jabber', 'skype', 'other'], | |||
'subtypes' => ['aim', 'icq', 'msn', 'yahoo', 'jabber', 'skype'], |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why 'other' is removed here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Because it's not supported by the rest of the code. It's not included in the vCard, so once you hit save the value is lost.
$map['work_state'] = "Work State"; | ||
$map['work_title'] = "Work Title"; | ||
$map['work_zip'] = "Work Zip"; | ||
$map['anniversary'][] = "Jahrestag"; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't like this change. We should keep this file syntax simple.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What is not simple about the syntax? This way, the mapping process is clearer. There is only one map of CSV field to vCard field rather than the CSV to internal ID, then a hard coded map of internl ID to vCard used currebtly. It also adds support variations of field names in the CSV file.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
$map['anniversary'][]
is not simple ;)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The reason for the nested array is to allow multiple labels to map to the same vCard field, e.g. currently the CSV labels first
and given_name
both map to vCard field firstname
. Currently this is done via the hard coded rcube_csv2vcard::$csv2vcard_map
. For me this is not simple. Adding a new field into the map means a change in 2 files, you have to know the hard coded map is there, there is no info about it in csv2vcard.inc
. Using a nested array may not be simple but for me it is simpler than the current approach as it means there is only 1 place to change when adding a new field.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I understand your approach but also understand Alec's concern and share the latter here. To me, csv2vcard.inc
is a config file, and so the priority should be readability for humans. Understanding the syntax is one thing (which might be hard for non-PHP-developers), another thing I don't understand without intimate knowledge of the code is why e.g. email:other
gets three values:
$map['email:other'][] = "E-mail Address";
$map['email:other'][] = "E-mail 2 Address";
$map['email:other'][] = "E-mail 3 Address";
Can we find a way to specify the mapping while keeping your approach (which I do like!) to de-duplicate and strip indirection?
You're removing this variable in this PR already and to me it looks like information gets lost there, because there's no mapping e.g. of |
I should have updated my comment when I changed my approach. You are totally right that this PR now removes that variable. It happens in this commit.
The $map['email:other'][] = "E-mail Address";
$map['email:other'][] = "E-mail 2 Address";
$map['email:other'][] = "E-mail 3 Address"; |
For #9419
Some of the mappings in the current code work (pass the tests) but the result is different to what you get if you create the same contact manually through the UI and then export it as a vCard, for example Roundcube uses
phone:mobile
notphone:cell
and there is noemail:pref
field. I have changed the mapping so it matches the fields in the UI. I added some more aliasesrcube_vcard
to show existing vCards with mismatched fields nicely.I have removed the subtype
other
from the IM field because that does not exist inrcube_vcard
which means if when you hit save in the UI the value simply disappears, it’s not saved.I have removed the variable
rcube_csv2vcard::$label_map
because it’s a duplicate of contents of/program/localization/en_US/csv2vcard.inc
and just a bit confusing currently/program/localization/en_US/csv2vcard.inc
is not used by the code and this PR changes that.I have another reason for wanting to use
/program/localization/en_US/csv2vcard.inc
overrcube_csv2vcard::$label_map
and if this PR gets merged then I will propose 1 additional change which will remove thercube_csv2vcard::$csv2vcard_map
variable and simplify the mapping process by storing both the source and destination for the map in/program/localization/en_US/csv2vcard.inc
and allowing multiple sources (including multiple languages) for the same destination. This is a slightly larger and may be more controversial change hence the separate PR.