0

我正在建立一个艺术家目录并使用 Pixel & Tonic 的 Playa 来管理每个成员的“粉丝”。

在每个用户的个人资料中,有一个多选 Playa 字段,显示用户“粉丝”的所有成员(类似于 Facebook 上的“喜欢”)。

我想做的是有一个“链接”,它实际上是一个安全破解提交,它将成员的名字添加到用户的 Playa 字段。

本质上,它将是一个表单,其中包含用户 ID 和正在查看其页面的成员的屏幕名称的隐藏字段。我想将屏幕名称附加到用户现有的 Playa 字段条目中。

实现这一目标的最佳方法是什么?

谢谢!

4

2 回答 2

4

您也可以使用 Safecracker,并为 Playa 创建隐藏字段:

<input type="hidden" name="my_playa_field_name[selections][]" />

您必须在此处使用 Playa 字段名称(而不是 field_id)。

然后你可以在 ajax 中提交你的 Safecracker 表单。

于 2012-04-02T09:58:01.933 回答
1

您需要添加一个自定义插件来执行此操作,以便您可以执行自定义 SQL 插入。

不确定您是否熟悉编写插件,但您可以通过pkg.io创建一个插件,然后将此函数添加到生成的文件中。然后,您可以创建一个指向放置新标签的模板的链接,并可能通过段传递成员和新粉丝的 ID:

{exp:my_plugin:add_fan member_id="{segment_3}" fan_id="{segment_4}"}

此函数假设(可能是错误的)您将成员存储在频道中(我假设是这样,因为您使用的是 Playa 字段),并且您可以在模板中访问成员和粉丝的 entry_id . 如果没有,您可能需要执行更多查询才能找到每个查询的 entry_id。它还调用您的 Playa 字段field_id_10......您需要10用您的 Playa 字段的正确 field_id 替换。

function add_fan()
{
    $this->EE =& get_instance();

    $member_id = $this->EE->TMPL->fetch_param('member_id');
    $fan_id = $this->EE->TMPL->fetch_param('fan_id');

    $data = array(
        'parent_entry_id' => $member_id,
        'child_entry_id' => $fan_id,
        'parent_field_id' => 10
    );

    $this->EE->db->query(
        $this->EE->db->insert_string('exp_playa_relationships', $data)
    );
}
于 2012-03-29T16:17:35.687 回答