Social Icons

Wednesday, July 24, 2013

CREDIT MEMO APPLY SCRIPT


DECLARE
   k_api_version        CONSTANT NUMBER                                  := 1;
   k_init_msg_list      CONSTANT VARCHAR2 (1)              := fnd_api.g_false;
   k_comments           CONSTANT ar_receivable_applications.comments%TYPE
                                                 := 'JUN APPLIED TRANSACTION';
   k_commit             CONSTANT VARCHAR2 (1)              := fnd_api.g_false;
   l_acctd_amount_applied_from   ar_receivable_applications_all.acctd_amount_applied_from%TYPE;
   l_acctd_amount_applied_to     ar_receivable_applications_all.acctd_amount_applied_to%TYPE;
   l_cm_app_rec                  ar_cm_api_pub.cm_app_rec_type;
   l_msg_count                   NUMBER;
   l_msg_data                    VARCHAR2 (255);
   l_out_rec_application_id      NUMBER;
   l_return_status               VARCHAR2 (1);
   credit_memo_customer_trx_id   NUMBER;
   invoice_customer_trx_id       NUMBER;

   CURSOR trx_lines_to_ar_c
   IS
      SELECT   trx_number, account_number, customer_name,
               applied_to_trx_number, amount_applied, apply_date, gl_date
          FROM oomco_cm_appply
         WHERE invoice_currency_code = 'OMR' AND sno NOT IN (1, 2)
      ORDER BY 1;
BEGIN
-- First set the environment of the user submitting the request by submitting
-- fnd_global.apps_initialize().
-- The procedure requires three parameters
-- Fnd_Global.apps_initialize(userId,responsibilityId,applicationId)
-- replace the following code with correct value as get from sql above
   FOR c1 IN trx_lines_to_ar_c
   LOOP
      mo_global.init ('AR');
      mo_global.set_policy_context ('S', '82');
      fnd_global.apps_initialize (1110, 20678, 222, 0);

      BEGIN
         SELECT customer_trx_id
           INTO credit_memo_customer_trx_id
           FROM ra_customer_trx_all a, hz_cust_accounts_all b, hz_parties c
          WHERE a.bill_to_customer_id = b.cust_account_id
            AND b.party_id = c.party_id
            AND a.trx_number = c1.trx_number
            AND b.account_number = c1.account_number
            AND UPPER (TRIM (c.party_name)) = UPPER (TRIM (c1.customer_name));
      EXCEPTION
         WHEN OTHERS
         THEN
            DBMS_OUTPUT.put_line
                          (   'Credit Memo Transaction Number does not exist'
                           || c1.trx_number
                          );
      END;

      BEGIN
         SELECT customer_trx_id
           INTO invoice_customer_trx_id
           FROM ra_customer_trx_all a, hz_cust_accounts_all b, hz_parties c
          WHERE a.bill_to_customer_id = b.cust_account_id
            AND b.party_id = c.party_id
            AND a.trx_number = c1.applied_to_trx_number
            AND b.account_number = c1.account_number
            AND UPPER (TRIM (c.party_name)) = UPPER (TRIM (c1.customer_name));
      EXCEPTION
         WHEN OTHERS
         THEN
            DBMS_OUTPUT.put_line (   'Invoice Number does not exist'
                                  || c1.applied_to_trx_number
                                 );
      END;

      l_cm_app_rec.cm_customer_trx_id := credit_memo_customer_trx_id;
      l_cm_app_rec.cm_trx_number := NULL;                -- Credit Memo Number
      l_cm_app_rec.inv_customer_trx_id := invoice_customer_trx_id;
      l_cm_app_rec.inv_trx_number := NULL;                   -- Invoice Number
      l_cm_app_rec.installment := NULL;
      l_cm_app_rec.applied_payment_schedule_id := NULL;
      l_cm_app_rec.amount_applied := c1.amount_applied;
      l_cm_app_rec.apply_date := TRUNC (c1.apply_date);
      l_cm_app_rec.gl_date := TRUNC (c1.gl_date);
      l_cm_app_rec.inv_customer_trx_line_id := NULL;
      l_cm_app_rec.inv_line_number := NULL;
      l_cm_app_rec.show_closed_invoices := NULL;
      l_cm_app_rec.ussgl_transaction_code := NULL;
      l_cm_app_rec.attribute_category := NULL;
      l_cm_app_rec.attribute1 := NULL;
      l_cm_app_rec.attribute2 := NULL;
      l_cm_app_rec.attribute3 := NULL;
      l_cm_app_rec.attribute4 := NULL;
      l_cm_app_rec.attribute5 := NULL;
      l_cm_app_rec.attribute6 := NULL;
      l_cm_app_rec.attribute7 := NULL;
      l_cm_app_rec.attribute8 := NULL;
      l_cm_app_rec.attribute9 := NULL;
      l_cm_app_rec.attribute10 := NULL;
      l_cm_app_rec.attribute11 := NULL;
      l_cm_app_rec.attribute12 := NULL;
      l_cm_app_rec.attribute13 := NULL;
      l_cm_app_rec.attribute14 := NULL;
      l_cm_app_rec.attribute15 := NULL;
      l_cm_app_rec.global_attribute_category := NULL;
      l_cm_app_rec.global_attribute1 := NULL;
      l_cm_app_rec.global_attribute2 := NULL;
      l_cm_app_rec.global_attribute3 := NULL;
      l_cm_app_rec.global_attribute4 := NULL;
      l_cm_app_rec.global_attribute5 := NULL;
      l_cm_app_rec.global_attribute6 := NULL;
      l_cm_app_rec.global_attribute7 := NULL;
      l_cm_app_rec.global_attribute8 := NULL;
      l_cm_app_rec.global_attribute9 := NULL;
      l_cm_app_rec.global_attribute10 := NULL;
      l_cm_app_rec.global_attribute11 := NULL;
      l_cm_app_rec.global_attribute12 := NULL;
      l_cm_app_rec.global_attribute12 := NULL;
      l_cm_app_rec.global_attribute14 := NULL;
      l_cm_app_rec.global_attribute15 := NULL;
      l_cm_app_rec.global_attribute16 := NULL;
      l_cm_app_rec.global_attribute17 := NULL;
      l_cm_app_rec.global_attribute18 := NULL;
      l_cm_app_rec.global_attribute19 := NULL;
      l_cm_app_rec.global_attribute20 := NULL;
      l_cm_app_rec.comments := k_comments;
      l_cm_app_rec.called_from := NULL;
      ar_cm_api_pub.apply_on_account
                  (p_api_version                    => k_api_version,
                   p_init_msg_list                  => k_init_msg_list,
                   p_commit                         => k_commit,
                   p_cm_app_rec                     => l_cm_app_rec,
                   x_return_status                  => l_return_status,
                   x_msg_count                      => l_msg_count,
                   x_msg_data                       => l_msg_data,
                   x_out_rec_application_id         => l_out_rec_application_id,
                   x_acctd_amount_applied_from      => l_acctd_amount_applied_from,
                   x_acctd_amount_applied_to        => l_acctd_amount_applied_to
                  );
      COMMIT;
      DBMS_OUTPUT.put_line ('return_status: ' || l_return_status);
      DBMS_OUTPUT.put_line ('msg_count: ' || l_msg_count);
      DBMS_OUTPUT.put_line (   'out_rec_application_id: '
                            || l_out_rec_application_id
                           );
      DBMS_OUTPUT.put_line (   'acctd_amount_applied_from: '
                            || l_acctd_amount_applied_from
                           );
      DBMS_OUTPUT.put_line (   'acctd_amount_applied_to: '
                            || l_acctd_amount_applied_to
                           );

      IF l_msg_count = 1
      THEN
         DBMS_OUTPUT.put_line (l_msg_data);
      ELSIF l_msg_count > 1
      THEN
         FOR i IN 1 .. l_msg_count
         LOOP
            DBMS_OUTPUT.put_line
                      (   i
                       || '. '
                       || SUBSTR
                               (fnd_msg_pub.get (p_encoded      => fnd_api.g_false),
                                1,
                                255
                               )
                      );
         END LOOP;
      END IF;
   END LOOP;
END;

No comments :

Post a Comment

">