1

私はDynamicsAX2009を初めて使用しますが、自分が行っていることを解決する方法が実際には見つからないため、ここで質問することにしました。

X ++を介して請求書を転記(?)する必要があります。

私はすでにこのHOWTOを見つけました:FacturaciónselectivadelíneasenDynamics AX、そしてそれがスペイン語であるとしても、あなたはその考えを理解すると思います。

リンクから変更したコードは次のとおりです。

static void JAEE_PurchFormLetter(Args _args)
{
    Num                 _invoiceNum;    // Núm. factura
    TransDate           _invoiceDate;   // Fecha factura

    MyPurchFormLetter     purchFormLetter =       PurchFormLetter::construct(DocumentStatus::Invoice);
    PurchParmUpdate     purchParmUpdate;
    PurchParmTable      purchParmTable;
    PurchParmLine       purchParmLine;

    TradeLineRefId      tableRefId;
    PurchTable          purchTable;
    PurchLine           purchLine;
    ;

    ttsbegin;

    _invoiceNum = 'Facbyjob';
    _invoiceDate = str2date('14-01-2013', 123);

    purchTable = PurchTable::find('00000019_062'); // Primer pedido
    // Inizializar purchFormLetter con el primer pedido
    purchFormLetter.parmCallerTable(purchTable);
    purchFormLetter.callInitParmPurchTable(purchTable);
    purchFormLetter.proforma(false);                                // Proforma: NO     (Registrar: SI)
    purchFormLetter.enableUpdateNowField(true);                     // Actualizar ahora: SI
    purchFormLetter.printFormLetter(false);                         // Imprimir: NO
    purchFormLetter.transDate(_invoiceDate);                        // Fecha de factura

    // Inizializar purchParmUpdate con el primer pedido
    purchParmUpdate.clear();
    purchParmUpdate.initValue();
    purchParmUpdate.ParmId              = purchFormLetter.parmId();
    purchParmUpdate.SumBy               = AccountOrder::Account;    // Agrupar por cliente
    purchParmUpdate.SumNum              = _invoiceNum;              // Núm. Factura
    purchParmUpdate.SpecQty             = PurchUpdate::All;         // Actualizar: Todo
    purchParmUpdate.DocumentStatus      = DocumentStatus::Invoice;  // Tipo documento: Factura
    purchParmUpdate.Proforma            = NoYes::No;                // Proforma: NO
    purchParmUpdate.SumIncludePending   = NoYes::No;                // Incluir pendiente: NO
    if (purchParmUpdate.validateWrite())
        purchParmUpdate.insert();
    else
        throw Exception::Error;

    purchFormLetter.purchParmUpdate(purchParmUpdate);
    purchFormLetter.parmParmTableNum(purchParmUpdate.SumNum);

    // Tabla temporal, se crea un registro de cabecera del primer pedido (sólo uno)
    purchParmTable.clear();
    purchParmTable.TableRefId = FormLetter::getTableRef();
    purchFormLetter.createParmTable(purchParmTable, purchTable);
    if (purchParmTable.validateWrite())
        purchParmTable.insert();
    else
        throw Exception::Error;

    tableRefId  = purchParmTable.TableRefId;

    // BEGIN - LINEAS
    //       - Repetir para cada línea que se quiera facturar y para cada una y 
    //       - asignar las variabies purchTable y purchLine según proceda
    purchParmLine.clear();
    purchParmLine.initValue();

    // Ajustar cantidades según necesidades

    // Catnidades de compra
    [purchParmLine.ReceiveNow,
     purchParmLine.RemainBefore,
     purchParmLine.RemainAfter] = purchFormLetter.qtyPurch(purchLine, naReal());

    // Cantidades de inventario
    [purchParmLine.InventNow,
     purchParmLine.RemainBeforeInvent,
     purchParmLine.RemainAfterInvent] = purchFormLetter.qtyInvent(purchLine, naReal());

    if (purchParmLine.ReceiveNow)
    {
        purchParmLine.ParmId = purchParmUpdate.ParmId;
        purchParmLine.initFromPurchLine(purchLine);
        purchParmLine.setLineAmount();
        purchParmLine.TableRefId = tableRefId;

        if (purchParmLine.validateWrite())
            purchParmLine.insert();
        else
            throw Exception::Error;
    }
    // END - LINEAS

    // Registrar!
    purchFormLetter.reArrangeNow(false); // No organizar
    purchFormLetter.run();

    ttscommit;
}

私の質問はこの行にあります: purchFormLetter.callInitParmPurchTable(purchTable);

initParmPurchTable()PurchFormLetterの派生クラス内から呼び出す必要があるのはなぜですか?

また、これを達成する方法は?メソッドを追加して、MyPurchFormLetter拡張する独自のクラスを宣言しようとしましたが、コードを実行しようとすると、コンパイラはオブジェクトにメソッドがないことを通知します。PurchFormLettercallInitParmPurchTable()

それは読みます:

Error al ejecutar código: Object objeto no tiene el método 'callInitParmPurchTable'.

編集:

私がやったことは、オブジェクトの一部であるような方法で、クラスにメソッドを追加することです。しかし、これが正しいアプローチではないと思うので、私は質問を開いたままにしておきます。callInitParmPurchTable()

4

2 に答える 2

2

PurchFormLetter::construct(DocumentStatus::Invoice);MyPurchFormLetterを返す ように変更しましたか?

「コンパイルフォワード」機能も調べてください

于 2013-01-15T08:46:25.153 に答える
0

私は次のことを発見しました:

PurchFormLetterを継承し、そこに実装するクラスを作成して、callInitParmPurchTable()明らかに実行するメソッドであるメソッドを実装するのは正しいことinitParmPurchTable()です。

おそらく、私が見逃していた部分の1つはMyPurchFormLetter、コンパイラがメソッドが存在することを認識できるようにコンパイルすることでした。

于 2013-01-16T16:32:46.937 に答える