Sharepoint используя ссылку JS

У меня есть требование от клиента показывать процент от значения столбца от суммы столбца, как показано на рисунке ниже, без виджета. желательно, чтобы я использовал ссылку JS в sharepoint. пожалуйста, дайте мне знать, если это то, что мы можем сделать с помощью ссылки JS.

1 ответ

Решил сделать это с получателем событий и хотел бы поделиться кодом, если у кого-то есть подобное требование. Приемник событий позволяет легко получить сумму столбца и получить процент для каждой строки. посмотрите код для события ItemAdded, но вы бы хотели добавить один и тот же код для событий ItemUpdated и ItemDeleted, чтобы они соответствующим образом отражали обновление.

    public override void ItemAdded(SPItemEventProperties properties)
    {

        base.ItemAdded(properties);
        string listName = "your list name goes here";
        using (SPWeb web = properties.OpenWeb())
        {
            if (web.Lists[listName] != null)
            {
                try
                {
                    SPList splist = web.Lists[listName];
                    int sum = 0;
                    foreach (SPListItem item in splist.Items)
                    {
                        sum = sum + Convert.ToInt32(item["Values"]);
                    }
                    //LoggingService

                    foreach (SPListItem item in splist.Items)
                    {
                        string percentage = string.Empty;
                        int percent = Convert.ToInt32(item["Values"]);/// Convert.ToInt32(sum);
                        double questient = (double)percent / sum;

                        percentage = questient.ToString("P1", CultureInfo.InvariantCulture);
                        item["Percent & widget"] = percentage;
                        this.EventFiringEnabled = false;
                        item.Update();
                        this.EventFiringEnabled = true;

                    }

                }
                catch (Exception ex)
                {

                    // LoggingService
                }

            } // end if
        }  // end using
    }
Другие вопросы по тегам