1
0
mirror of https://github.com/owncloudarchive/contacts.git synced 2025-01-18 07:52:21 +01:00

Re-added deleting properties.

This commit is contained in:
Thomas Tanghus 2012-10-23 06:27:22 +02:00
parent 7e52c45675
commit 2dba1d3672
4 changed files with 119 additions and 28 deletions

View File

@ -27,18 +27,37 @@ OCP\JSON::callCheck();
require_once __DIR__.'/../loghandler.php';
$id = $_POST['id'];
$checksum = $_POST['checksum'];
$id = isset($_POST['id']) ? $_POST['id'] : null;
$name = isset($_POST['name']) ? $_POST['name'] : null;
$checksum = isset($_POST['checksum']) ? $_POST['checksum'] : null;
$l10n = OC_Contacts_App::$l10n;
$vcard = OC_Contacts_App::getContactVCard( $id );
$line = OC_Contacts_App::getPropertyLineByChecksum($vcard, $checksum);
if(is_null($line)) {
bailOut($l10n->t('Information about vCard is incorrect. Please reload the page.'));
exit();
$multi_properties = array('EMAIL', 'TEL', 'IMPP', 'ADR', 'URL');
if(!$id) {
bailOut(OC_Contacts_App::$l10n->t('id is not set.'));
}
unset($vcard->children[$line]);
if(!$name) {
bailOut(OC_Contacts_App::$l10n->t('element name is not set.'));
}
if(!$checksum && in_array($name, $multi_properties)) {
bailOut(OC_Contacts_App::$l10n->t('checksum is not set.'));
}
$vcard = OC_Contacts_App::getContactVCard( $id );
if(!is_null($checksum)) {
$line = OC_Contacts_App::getPropertyLineByChecksum($vcard, $checksum);
if(is_null($line)) {
bailOut($l10n->t('Information about vCard is incorrect. Please reload the page.'));
exit();
}
unset($vcard->children[$line]);
} else {
unset($vcard->{$name});
}
try {
OC_Contacts_VCard::edit($id, $vcard);

View File

@ -45,8 +45,9 @@ input:hover:not([type="checkbox"]), input:active:not([type="checkbox"]), textare
dl.form { display: inline-block; width: auto; margin: 0; padding: 0; cursor: normal; }
.form dt { display: table-cell; clear: left; float: left; width: 7em; margin: 0; padding: 0.8em 0.5em 0 0; text-align:right; text-overflow:ellipsis; o-text-overflow: ellipsis; vertical-align: text-bottom; color: #bbb;/* white-space: pre-wrap; white-space: -moz-pre-wrap !important; white-space: -pre-wrap; white-space: -o-pre-wrap;*/ }
.form dd { display: table-cell; clear: right; float: left; margin: 0; padding: 0; white-space: nowrap; vertical-align: text-bottom; }
.action { display: inline-block; }
.add { background:url('%webroot%/core/img/actions/add.svg') no-repeat center; clear: both; }
.delete { background:url('%webroot%/core/img/actions/delete.svg') no-repeat center; }
.delete { background:url('%webroot%/core/img/actions/delete.png') no-repeat center; }
.edit { background:url('%webroot%/core/img/actions/rename.svg') no-repeat center; }
.share { background:url('%webroot%/core/img/actions/share.svg') no-repeat center; }
.mail { background:url('%webroot%/core/img/actions/mail.svg') no-repeat center; }

View File

@ -38,10 +38,6 @@ OC.Contacts = OC.Contacts || {};
}
}
Contact.prototype.removeProperty = function(obj) {
console.log('Contact.removeProperty', name)
}
Contact.prototype.addProperty = function($option, name) {
console.log('Contact.addProperty', name)
switch(name) {
@ -75,6 +71,54 @@ OC.Contacts = OC.Contacts || {};
}
}
Contact.prototype.deleteProperty = function(params) {
var obj = params.obj;
if(!this.enabled) {
return;
}
var element = this.propertyTypeFor(obj);
var $container = this.propertyContainerFor(obj);
console.log('Contact.deleteProperty, element', element, $container);
var params = {
name: element,
id: this.id
};
if(this.multi_properties.indexOf(element) !== -1) {
params['checksum'] = this.checksumFor(obj);
}
this.setAsSaving(obj, true);
var self = this;
$.post(OC.filePath('contacts', 'ajax', 'contact/deleteproperty.php'), params, function(jsondata) {
if(!jsondata) {
$(document).trigger('status.contact.error', {
status: 'error',
message: t('contacts', 'Network or server error. Please inform administrator.'),
});
self.setAsSaving(obj, false);
return false;
}
if(jsondata.status == 'success') {
// TODO: Remove from internal data structure
if(self.multi_properties.indexOf(element) !== -1) {
$container.remove();
} else {
self.setAsSaving(obj, false);
self.$fullelem.find('[data-element="' + element.toLowerCase() + '"]').hide();
$container.find('input.value').val('');
self.$addMenu.find('option[value="' + element.toUpperCase() + '"]').prop('disabled', false);
}
return true;
} else {
$(document).trigger('status.contact.error', {
status: 'error',
message: jsondata.data.message,
});
self.setAsSaving(obj, false);
return false;
}
},'json');
}
/**
* @brief Act on change of a property.
* If this is a new contact it will first be saved to the datastore and a
@ -93,6 +137,7 @@ OC.Contacts = OC.Contacts || {};
if(params.obj) {
obj = params.obj;
q = this.queryStringFor(obj);
element = this.propertyTypeFor(obj);
} else {
element = params.name;
q += 'value=' + encodeURIComponent(params.value) + '&name=' + element;
@ -110,8 +155,15 @@ OC.Contacts = OC.Contacts || {};
return false;
}
if(jsondata.status == 'success') {
console.log(self.data[element]);
if(!self.data[element]) {
self.data[element] = [];
}
if(self.multi_properties.indexOf(element) !== -1) {
$container.data('checksum', jsondata.data.checksum);
self.propertyContainerFor(obj).data('checksum', jsondata.data.checksum);
} else {
// TODO: Save value and parameters internally
self.data[element][0] = {name: element};
}
self.setAsSaving(obj, false);
return true;
@ -216,7 +268,7 @@ OC.Contacts = OC.Contacts || {};
q += '&value=' + encodeURIComponent($(obj).val());
} else {
q += '&' + this.propertyContainerFor(obj)
.find('input.value,select.value,textarea.value').serialize();
.find('input.value,select.value,textarea.value,.parameter').serialize();
}
return q;
}
@ -291,7 +343,22 @@ OC.Contacts = OC.Contacts || {};
self.addProperty($opt, $(this).val());
$(this).val('');
});
this.$fullelem.on('change', '.value', function(event) {
var $singleelements = this.$fullelem.find('dd.propertycontainer');
$singleelements.find('.action').css('opacity', '0');
$singleelements.on('mouseenter', function() {
$(this).find('.action').css('opacity', '1');
}).on('mouseleave', function() {
$(this).find('.action').css('opacity', '0');
});
this.$fullelem.on('click keydown', '.delete', function(event) {
console.log('delete', event);
$('.tipsy').remove();
if(wrongKey(event)) {
return;
}
self.deleteProperty({obj:event.target});
});
this.$fullelem.on('change', '.value,.parameter', function(event) {
console.log('change', event);
self.saveProperty({obj:event.target});
});

View File

@ -89,7 +89,7 @@
<script id="contactListItemTemplate" type="text/template">
<tr class="contact" data-id="{id}">
<td class="name"
<td class="name"
style="background: url('<?php echo OCP\Util::linkTo('contacts', 'thumbnail.php'); ?>?id={id}')">
<input type="checkbox" name="id" value="{id}" />{name}
</td>
@ -129,24 +129,28 @@
</dt>
<dd data-element="nickname" class="propertycontainer">
<input class="value" type="text" name="value" value="{nickname}" />
<a role="button" class="action delete" title="<?php echo $l->t('Delete'); ?>"></a>
</dd>
<dt data-element="title">
<?php echo $l->t('Title'); ?>
</dt>
<dd data-element="title" class="propertycontainer">
<input class="value" type="text" name="value" value="{title}" />
<a role="button" class="action delete" title="<?php echo $l->t('Delete'); ?>"></a>
</dd>
<dt data-element="org">
<?php echo $l->t('Organization'); ?>
</dt>
<dd data-element="org" class="propertycontainer">
<input class="value" type="text" name="value" value="{org}" />
<a role="button" class="action delete" title="<?php echo $l->t('Delete'); ?>"></a>
</dd>
<dt data-element="bday">
<?php echo $l->t('Birthday'); ?>
</dt>
<dd data-element="bday" class="propertycontainer">
<input class="value" type="text" name="value" value="{bday}" />
<a role="button" class="action delete" title="<?php echo $l->t('Delete'); ?>"></a>
</dd>
</dl>
</div>
@ -199,10 +203,10 @@
<script id="contactDetailsTemplate" class="hidden" type="text/template">
<div class="email">
<li data-element="email" data-checksum="{checksum}" class="propertycontainer">
<select class="rtl type value" name="parameters[TYPE][]">
<select class="rtl type parameter" name="parameters[TYPE][]">
<?php echo OCP\html_select_options($_['email_types'], array()) ?>
</select>
<input type="checkbox" class="value tip" name="parameters[TYPE][]" value="PREF" title="<?php echo $l->t('Preferred'); ?>" />
<input type="checkbox" class="parameter tip" name="parameters[TYPE][]" value="PREF" title="<?php echo $l->t('Preferred'); ?>" />
<input type="email" required="required" class="nonempty value" name="value" value="{value}" x-moz-errormessage="<?php echo $l->t('Please specify a valid email address.'); ?>" placeholder="<?php echo $l->t('someone@example.com'); ?>" />
<span class="listactions">
<a class="action mail" title="<?php echo $l->t('Mail to address'); ?>"></a>
@ -212,10 +216,10 @@
</div>
<div class="tel">
<li data-element="tel" data-checksum="{checksum}" class="propertycontainer">
<select class="rtl type value" name="parameters[TYPE][]">
<select class="rtl type parameter" name="parameters[TYPE][]">
<?php echo OCP\html_select_options($_['phone_types'], array()) ?>
</select>
<input type="checkbox" class="value tip" name="parameters[TYPE][]" value="PREF" title="<?php echo $l->t('Preferred'); ?>" />
<input type="checkbox" class="parameter tip" name="parameters[TYPE][]" value="PREF" title="<?php echo $l->t('Preferred'); ?>" />
<input type="tel" required="required" class="nonempty value" name="value" value="{value}" placeholder="<?php echo $l->t('Enter phone number'); ?>" />
<span class="listactions">
<a role="button" class="action delete" title="<?php echo $l->t('Delete phone number'); ?>"></a>
@ -224,10 +228,10 @@
</div>
<div class="url">
<li data-element="url" data-checksum="{checksum}" class="propertycontainer">
<select class="rtl type value" name="parameters[TYPE][]">
<select class="rtl type parameter" name="parameters[TYPE][]">
<?php echo OCP\html_select_options($_['email_types'], array()) ?>
</select>
<input type="checkbox" class="value tip" name="parameters[TYPE][]" value="PREF" title="<?php echo $l->t('Preferred'); ?>" />
<input type="checkbox" class="parameter tip" name="parameters[TYPE][]" value="PREF" title="<?php echo $l->t('Preferred'); ?>" />
<input type="url" required="required" class="nonempty value" name="value" value="{value}" placeholder="http://www.example.com/" />
<span class="listactions">
<a role="button" class="action globe" title="<?php echo $l->t('Go to web site'); ?>">
@ -237,10 +241,10 @@
</div>
<div class="adr">
<li data-element="adr" data-checksum="{checksum}" class="propertycontainer">
<select class="rtl type value" name="parameters[TYPE][]">
<select class="rtl type parameter" name="parameters[TYPE][]">
<?php echo OCP\html_select_options($_['adr_types'], array()) ?>
</select>
<input type="checkbox" class="value tip" name="parameters[TYPE][]" value="PREF" title="<?php echo $l->t('Preferred'); ?>" />
<input type="checkbox" class="parameter tip" name="parameters[TYPE][]" value="PREF" title="<?php echo $l->t('Preferred'); ?>" />
<span class="float adr">{value}</span>
<span class="listactions">
<a class="action globe" title="<?php echo $l->t('View on map'); ?>"></a>
@ -257,12 +261,12 @@
</div>
<div class="impp">
<li data-element="impp" data-checksum="{checksum}" class="propertycontainer">
<select class="type value" name="parameters[TYPE][]">
<select class="type parameter" name="parameters[TYPE][]">
<?php echo OCP\html_select_options($_['impp_types'], array()) ?>
</select>
<input type="checkbox" class="value impp tip" name="parameters[TYPE][]" value="PREF" title="<?php echo $l->t('Preferred'); ?>" />
<input type="checkbox" class="parameter impp tip" name="parameters[TYPE][]" value="PREF" title="<?php echo $l->t('Preferred'); ?>" />
<div class="select_wrapper">
<select class="rtl value label impp" name="parameters[X-SERVICE-TYPE]">
<select class="rtl parameter label impp" name="parameters[X-SERVICE-TYPE]">
<?php echo OCP\html_select_options($_['im_protocols'], array()) ?>
</select>
</div>