Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
K
KGOrders
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Cam Hayes
KGOrders
Commits
7f19b291
Commit
7f19b291
authored
Dec 05, 2024
by
Elias Sarraf
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/cam'
parents
e3cf4538
bfd278e3
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
544 additions
and
307 deletions
+544
-307
View.Main.pas
kgOrdersClient/View.Main.pas
+3
-3
View.OrderEntryCorrugated.dfm
kgOrdersClient/View.OrderEntryCorrugated.dfm
+31
-14
View.OrderEntryCorrugated.html
kgOrdersClient/View.OrderEntryCorrugated.html
+94
-98
View.OrderEntryCorrugated.pas
kgOrdersClient/View.OrderEntryCorrugated.pas
+36
-6
View.OrderList.dfm
kgOrdersClient/View.OrderList.dfm
+206
-51
View.OrderList.pas
kgOrdersClient/View.OrderList.pas
+112
-120
View.Orders.pas
kgOrdersClient/View.Orders.pas
+15
-8
app.css
kgOrdersClient/template/css/app.css
+6
-1
Auth.Database.dfm
kgOrdersServer/Source/Auth.Database.dfm
+0
-1
Database.dfm
kgOrdersServer/Source/Database.dfm
+0
-1
Lookup.Service.pas
kgOrdersServer/Source/Lookup.Service.pas
+8
-1
Lookup.ServiceImpl.pas
kgOrdersServer/Source/Lookup.ServiceImpl.pas
+31
-1
kgOrdersServer.ini
kgOrdersServer/kgOrdersServer.ini
+2
-2
No files found.
kgOrdersClient/View.Main.pas
View file @
7f19b291
...
...
@@ -51,7 +51,7 @@ type
procedure
ShowForm
(
AFormClass
:
TWebFormClass
);
procedure
EditUser
(
Mode
,
Username
,
Password
,
Name
,
Status
,
Email
,
Access
,
Rights
,
Perspective
,
QB
:
string
);
procedure
ViewOrderEntry
(
orderInfo
,
mode
:
string
);
procedure
ViewOrderEntry
(
orderInfo
,
customerInfo
,
mode
:
string
);
procedure
ViewOrders
(
info
:
string
);
procedure
ShowUserForm
(
Info
:
string
);
end
;
...
...
@@ -227,12 +227,12 @@ begin
end
;
procedure
TFViewMain
.
ViewOrderEntry
(
orderInfo
,
mode
:
string
);
procedure
TFViewMain
.
ViewOrderEntry
(
orderInfo
,
customerInfo
,
mode
:
string
);
begin
lblAppTitle
.
Caption
:=
'Koehler-Gibson Order Entry'
;
if
Assigned
(
FChildForm
)
then
FChildForm
.
Free
;
FChildForm
:=
TFOrderEntry
.
CreateForm
(
WebPanel1
.
ElementID
,
orderInfo
,
mode
);
FChildForm
:=
TFOrderEntry
.
CreateForm
(
WebPanel1
.
ElementID
,
orderInfo
,
customerInfo
,
mode
);
end
;
procedure
TFViewMain
.
ShowUserForm
(
Info
:
string
);
...
...
kgOrdersClient/View.OrderEntryCorrugated.dfm
View file @
7f19b291
...
...
@@ -239,13 +239,14 @@ object FOrderEntry: TFOrderEntry
object edtCompanyName: TWebDBEdit
Left = 24
Top = 92
Width =
121
Width =
260
Height = 22
AutoSize = True
ChildOrder = 79
ElementID = 'edtcompanyname'
HeightPercent = 100.000000000000000000
MaxLength = 90
WidthStyle = ssAuto
WidthPercent = 100.000000000000000000
DataField = 'NAME'
DataSource = WebDataSource1
...
...
@@ -327,19 +328,6 @@ object FOrderEntry: TFOrderEntry
DataField = 'staff_fields_invoice_to'
DataSource = WebDataSource1
end
object edtShipTo: TWebDBEdit
Left = 26
Top = 430
Width = 121
Height = 22
AutoSize = True
ChildOrder = 79
ElementID = 'edtshipto'
HeightPercent = 100.000000000000000000
WidthPercent = 100.000000000000000000
DataField = 'staff_fields_ship_to'
DataSource = WebDataSource1
end
object edtPONumber: TWebDBEdit
Left = 26
Top = 458
...
...
@@ -965,6 +953,20 @@ object FOrderEntry: TFOrderEntry
HeightPercent = 100.000000000000000000
WidthPercent = 100.000000000000000000
end
object WebDBComboBox1: TWebDBComboBox
Left = 26
Top = 430
Width = 145
Height = 22
ElementID = 'wcbshipto'
HeightPercent = 100.000000000000000000
WidthPercent = 100.000000000000000000
ItemIndex = -1
DataField = 'staff_fields_ship_to'
DataSource = WebDataSource1
ListField = 'ADDRESS'
ListSource = wdsShipTo
end
object XDataWebClient1: TXDataWebClient
Connection = DMConnection.ApiConnection
Left = 244
...
...
@@ -1247,10 +1249,25 @@ object FOrderEntry: TFOrderEntry
object XDataWebDataSet1staff_fields_mount_due: TStringField
FieldName = 'staff_fields_mount_due'
end
object XDataWebDataSet1ADDRESS_LIST: TStringField
FieldName = 'ADDRESS_LIST'
end
end
object WebDataSource1: TWebDataSource
DataSet = XDataWebDataSet1
Left = 216
Top = 104
end
object wdsShipTo: TWebDataSource
DataSet = xdwdsShipTo
Left = 212
Top = 436
end
object xdwdsShipTo: TXDataWebDataSet
Left = 192
Top = 486
object xdwdsShipToADDRESS: TStringField
FieldName = 'ADDRESS'
end
end
end
kgOrdersClient/View.OrderEntryCorrugated.html
View file @
7f19b291
...
...
@@ -12,80 +12,76 @@
<div
class=
"row"
>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Company Name:
</label>
<input
id=
"edtcompanyname"
type=
"text"
class=
"form-control"
width=
150px
/
>
<input
id=
"edtcompanyname"
type=
"text"
class=
"form-control"
style=
"width: 300px;"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Account Company Name:
</label>
<input
id=
"edtaccountcompanyname"
type=
"text"
class=
"form-control"
width=
300px
/
>
<input
id=
"edtaccountcompanyname"
type=
"text"
class=
"form-control"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
In Quickbooks?:
</label>
<input
id=
"edtinquickbooks"
type=
"text"
class=
"form-control"
width=
300px
/
>
<input
id=
"edtinquickbooks"
type=
"text"
class=
"form-control"
style=
"width: 150px"
/>
</div>
</div>
<h4
class=
"custom-h4 mt-3"
>
Staff Fields
</h4>
<hr
class=
"custom-hr"
>
<div
class=
"row"
>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Order Date:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Order Date:
</label>
<input
class=
"form-control input-sm"
id=
"dtporderdate"
type=
"date"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Proof Date:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Proof Date:
</label>
<input
class=
"form-control input-sm"
id=
"dtpproofdate"
type=
"date"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Ship Date:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Ship Date:
</label>
<input
class=
"form-control input-sm"
id=
"dtpshipdate"
type=
"date"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Ship Via:
</label>
<input
id=
"edtshipvia"
type=
"text"
class=
"form-control"
width=
300px
/
>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Ship Via:
</label>
<input
id=
"edtshipvia"
type=
"text"
class=
"form-control"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Quantity:
</label>
<input
id=
"edtquantity"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Quantity:
</label>
<input
id=
"edtquantity"
class=
"form-control input-sm"
style=
"width: 100px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Price:
</label>
<input
id=
"edtprice"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Price:
</label>
<input
id=
"edtprice"
class=
"form-control input-sm"
style=
"width: 100px"
type=
"number"
min=
"0"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Invoice To:
</label>
<input
id=
"edtinvoiceto"
class=
"form-control input-sm"
width=
'50%'
/>
<div>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Invoice To:
</label>
<input
id=
"edtinvoiceto"
class=
"form-control input-sm"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Ship To:
</label>
<
input
id=
"edtshipto"
class=
"form-control input-sm"
width=
'50%'
/
>
<div>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Ship To:
</label>
<
select
id=
"wcbshipto"
class=
'form-select'
></select
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
PO Number:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
PO Number:
</label>
<input
id=
"edtponumber"
class=
"form-control input-sm"
width=
'50%'
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Job Name:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Job Name:
</label>
<input
id=
"edtjobname"
class=
"form-control input-sm"
width=
'50%'
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
QuickBooks Item:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
QuickBooks Item:
</label>
<input
id=
"edtquickbooksitem"
class=
"form-control input-sm"
width=
'50%'
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Art Due:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Art Due:
</label>
<input
class=
"form-control input-sm"
id=
"dtpartdue"
type=
"date"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Plate Due:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Plate Due:
</label>
<input
class=
"form-control input-sm"
id=
"dtpplatedue"
type=
"date"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Mount Due:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Mount Due:
</label>
<input
class=
"form-control input-sm"
id=
"dtpmountdue"
type=
"date"
>
</div>
<div
class=
"col-auto"
>
<label
class=
"form-label mt-2"
>
Art Location:
</label>
<input
id=
"edtartlocation"
class=
"form-control input-sm"
width=
'50%'
/>
</div>
</div>
<h4
class=
"custom-h4 mt-3"
>
Supplied by Customer
</h4>
<hr
class=
"custom-hr"
>
...
...
@@ -108,67 +104,67 @@
</div>
<div
class=
"col-auto"
>
<label
class=
'pe-2'
style=
"font-weight: 700; font-size: 15px;"
>
Email:
</label>
<input
type=
"checkbox"
id=
"edtemail"
width=
'50%'
/>
<input
type=
"checkbox"
id=
"edtemail"
/>
</div>
<div
class=
"col-auto"
>
<label
class=
'pe-2'
style=
"font-weight: 700; font-size: 15px;"
>
FTP:
</label>
<input
type=
"checkbox"
id=
"edtftp"
width=
'50%'
/>
<input
type=
"checkbox"
id=
"edtftp"
/>
</div>
<div
class=
"col-auto"
>
<label
class=
'pe-2'
style=
"font-weight: 700; font-size: 15px;"
>
Other:
</label>
<input
class=
"form-control input-sm"
id=
"edtother"
width=
'50%'
/>
<input
class=
"form-control input-sm"
id=
"edtother"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
class=
'pe-2'
style=
"font-weight: 700; font-size: 15px;"
>
Existing Cutting Die:
</label>
<input
type=
"checkbox"
id=
"edtexistingcuttingdie"
width=
'50%'
/>
<input
type=
"checkbox"
id=
"edtexistingcuttingdie"
/>
</div>
<div
class=
"col-auto"
>
<label
class=
'pe-2'
style=
"font-weight: 700; font-size: 15px;"
>
Ref Art Print Card:
</label>
<input
type=
"checkbox"
id=
"edtrefartprintcard"
width=
'50%'
/>
<input
type=
"checkbox"
id=
"edtrefartprintcard"
/>
</div>
<div
class=
"col-auto"
>
<label
class=
'pe-2'
style=
"font-weight: 700; font-size: 15px;"
>
Ref Art A PDF:
</label>
<input
type=
"checkbox"
id=
"edtrefartapdf"
width=
'50%'
/>
<input
type=
"checkbox"
id=
"edtrefartapdf"
/>
</div>
</div>
<h4
class=
"custom-h4 mt-3"
>
Layout
</h4>
<hr
class=
"custom-hr"
>
<div
class=
"row"
>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
RSC L:
</label>
<input
id=
"edtrscl"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
RSC L:
</label>
<input
id=
"edtrscl"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
RSC W:
</label>
<input
id=
"edtrscw"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
RSC W:
</label>
<input
id=
"edtrscw"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
RSC D:
</label>
<input
id=
"edtrscd"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
RSC D:
</label>
<input
id=
"edtrscd"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Die Cut No:
</label>
<input
class=
"form-control input-sm"
id=
"edtdiecutno"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Die Cut No:
</label>
<input
class=
"form-control input-sm"
id=
"edtdiecutno"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Across No:
</label>
<input
class=
"form-control input-sm"
id=
"edtacrossno"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Across No:
</label>
<input
class=
"form-control input-sm"
id=
"edtacrossno"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Around No:
</label>
<input
class=
"form-control input-sm"
id=
"edtaroundno"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Around No:
</label>
<input
class=
"form-control input-sm"
id=
"edtaroundno"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
CAD File:
</label>
<input
id=
"edtcadfile"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
CAD File:
</label>
<input
id=
"edtcadfile"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Excalibur Die:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Excalibur Die:
</label>
<input
type=
"checkbox"
id=
"cbexcaliburdie"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
RSC Style:
</label>
<input
id=
"edtrscstyle"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
RSC Style:
</label>
<input
id=
"edtrscstyle"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
</div>
<h4
class=
"custom-h4 mt-3"
>
Mounting
</h4>
...
...
@@ -177,55 +173,55 @@
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Loose:
</label>
<input
type=
"checkbox"
id=
"cbloose"
>
<input
id=
"edtloose"
class=
"form-control input-sm"
width=
'50%'
/>
<input
id=
"edtloose"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Sticky Bak:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Sticky Bak:
</label>
<input
type=
"checkbox"
id=
"cbstickybak"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Full Mount:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Full Mount:
</label>
<input
type=
"checkbox"
id=
"cbfullmount"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Strip Mount:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Strip Mount:
</label>
<input
type=
"checkbox"
id=
"cbstripmount"
>
<input
id=
"edtstripmount"
class=
"form-control input-sm"
width=
'50%'
/>
<input
id=
"edtstripmount"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Standard Setup:
</label>
<input
id=
"edtstandardsetup"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Standard Setup:
</label>
<input
id=
"edtstandardsetup"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Custom Backing:
</label>
<input
id=
"edtcustombacking"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Custom Backing:
</label>
<input
id=
"edtcustombacking"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Custom Adhesive:
</label>
<input
id=
"edtcustomadhesive"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Custom Adhesive:
</label>
<input
id=
"edtcustomadhesive"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
</div>
<h4
class=
"custom-h4 mt-3"
>
Colors
</h4>
<hr
class=
"custom-hr"
>
<div
class=
"row"
>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Cylinder Size:
</label>
<input
id=
"edtcylindersize"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Cylinder Size:
</label>
<input
id=
"edtcylindersize"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Machine Indent:
</label>
<input
id=
"edtmachineindent"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Machine Indent:
</label>
<input
id=
"edtmachineindent"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Cross Hairs:
</label>
<input
id=
"edtcrosshairs"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Cross Hairs:
</label>
<input
id=
"edtcrosshairs"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Clemson:
</label>
<input
id=
"edtclemson"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Clemson:
</label>
<input
id=
"edtclemson"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
</div>
<h4
class=
"custom-h4 mt-3"
>
Colors
</h4>
<hr
class=
"custom-hr"
>
<div
class=
"row"
>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Colors:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Colors:
</label>
<button
id=
"btnaddcolor"
class=
"btn btn-primary btn-sm float-end"
>
+
</button>
<div
id=
"additionalFields"
class=
"row mt-3"
></div>
</div>
...
...
@@ -234,51 +230,51 @@
<hr
class=
"custom-hr"
>
<div
class=
"row"
>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Fax:
</label>
<input
id=
"edtfax"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Fax:
</label>
<input
id=
"edtfax"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Fax Attn:
</label>
<input
id=
"edtfaxattn"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Fax Attn:
</label>
<input
id=
"edtfaxattn"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Email:
</label>
<input
id=
"edtproofemail"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Email:
</label>
<input
id=
"edtproofemail"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Email Attn:
</label>
<input
id=
"edtemailattn"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Email Attn:
</label>
<input
id=
"edtemailattn"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Ship To:
</label>
<input
id=
"edtproofshipto"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Ship To:
</label>
<input
id=
"edtproofshipto"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Full Size Panel:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Full Size Panel:
</label>
<input
type=
"checkbox"
id=
"cbfullsizepanel"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Print Card:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Print Card:
</label>
<input
type=
"checkbox"
id=
"cbprintcard"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Wide Format:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Wide Format:
</label>
<input
type=
"checkbox"
id=
"cbwideformat"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
PDF File:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
PDF File:
</label>
<input
type=
"checkbox"
id=
"cbpdffile"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Other:
</label>
<input
id=
"edtproofother"
class=
"form-control input-sm"
width=
'50%'
/>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Other:
</label>
<input
id=
"edtproofother"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Art Approved As Is:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Art Approved As Is:
</label>
<input
type=
"checkbox"
id=
"cbartapprovedasis"
>
</div>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label mt-2"
>
Approved Date:
</label>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label mt-2"
>
Approved Date:
</label>
<input
class=
"form-control input-sm"
id=
"dtpapproveddate"
type=
"date"
>
</div>
</div>
...
...
@@ -287,23 +283,23 @@
<div
class=
"row"
>
<div
class=
"col-auto"
>
<label
class=
'pe-2'
style=
"font-weight: 700; font-size: 15px;"
id=
"lblthickness"
>
Thickness:
</label>
<input
id=
"edtThickness"
class=
"form-control input-sm"
width=
'50%'
/>
<input
id=
"edtThickness"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
class=
'pe-2'
style=
"font-weight: 700; font-size: 15px;"
id=
"lblplatematerial"
>
Plate Material:
</label>
<input
id=
"edtplatematerial"
class=
"form-control input-sm"
width=
'50%'
/>
<input
id=
"edtplatematerial"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
<div
class=
"col-auto"
>
<label
class=
'pe-2'
style=
"font-weight: 700; font-size: 15px;"
id=
"lbljobnumber"
>
Job Number:
</label>
<input
id=
"edtjobnumber"
class=
"form-control input-sm"
width=
'50%'
/>
<input
id=
"edtjobnumber"
class=
"form-control input-sm"
style=
"width: 150px"
/>
</div>
</div>
<h4
class=
"custom-h4 mt-3"
>
General
</h4>
<hr
class=
"custom-hr"
>
<div
class=
"row"
>
<div
class=
"col-auto"
>
<label
for=
"wdbe_first_name"
class=
"form-label"
>
Special Instructions
</label>
<
input
type=
"text"
class=
"form-control"
id=
"edtspecialinstructions"
style=
"width: 300px;"
>
<label
for=
"wdbe_first_name"
style=
"font-weight: 700; font-size: 15px;"
class=
"form-label"
>
Special Instructions
</label>
<
textarea
id=
"edtspecialinstructions"
class=
"form-control"
style=
" width: 500px; height: 150px;"
></textarea
>
</div>
</div>
<div
class=
"row"
>
...
...
kgOrdersClient/View.OrderEntryCorrugated.pas
View file @
7f19b291
...
...
@@ -38,7 +38,6 @@ type
edtQuantity
:
TWebDBEdit
;
edtPrice
:
TWebDBEdit
;
edtInvoiceTo
:
TWebDBEdit
;
edtShipTo
:
TWebDBEdit
;
edtPONumber
:
TWebDBEdit
;
edtJobName
:
TWebDBEdit
;
edtQuickBooksItem
:
TWebDBEdit
;
...
...
@@ -182,11 +181,17 @@ type
cbStickyBak
:
TWebCheckBox
;
cbLoose
:
TWebCheckBox
;
cbExcaliburDie
:
TWebCheckBox
;
XDataWebDataSet1ADDRESS_LIST
:
TStringField
;
wdsShipTo
:
TWebDataSource
;
xdwdsShipTo
:
TXDataWebDataSet
;
xdwdsShipToADDRESS
:
TStringField
;
WebDBComboBox1
:
TWebDBComboBox
;
procedure
WebFormCreate
(
Sender
:
TObject
);
procedure
HideNotification
();
procedure
ShowNotification
(
Notification
:
string
);
procedure
WebFormShow
(
Sender
:
TObject
);
[
async
]
procedure
getOrder
(
Order_ID
:
string
);
[
async
]
procedure
getCustomer
(
customerID
:
string
);
procedure
tmrScrollTopTimer
(
Sender
:
TObject
);
procedure
WebButton1Click
(
Sender
:
TObject
);
procedure
addColorRow
(
num
,
Color
,
LPI
,
Size
:
string
);
...
...
@@ -197,10 +202,11 @@ type
FCurrentReportType
:
string
;
FSelectProc
:
TSelectProc
;
orderID
:
string
;
customerID
:
string
;
mode
:
string
;
//FJSONProc1: TJSONProc1;
public
class
function
CreateForm
(
AElementID
,
orderInfo
,
mode
:
string
):
TWebForm
;
class
function
CreateForm
(
AElementID
,
orderInfo
,
customerInfo
,
mode
:
string
):
TWebForm
;
end
;
var
...
...
@@ -333,7 +339,7 @@ begin
[
orderJSON
.
ToString
]));
end
;
class
function
TFOrderEntry
.
CreateForm
(
AElementID
,
orderInfo
,
mode
:
string
):
TWebForm
;
class
function
TFOrderEntry
.
CreateForm
(
AElementID
,
orderInfo
,
customerInfo
,
mode
:
string
):
TWebForm
;
var
localMode
:
string
;
begin
...
...
@@ -344,6 +350,7 @@ begin
with
TFOrderEntry
(
AForm
)
do
begin
HideNotification
;
TFOrderEntry
(
AForm
).
customerID
:=
customerInfo
;
TFOrderEntry
(
AForm
).
orderID
:=
orderInfo
;
TFOrderEntry
(
AForm
).
mode
:=
localMode
;
console
.
log
(
TFOrderEntry
(
AForm
).
mode
);
...
...
@@ -362,7 +369,6 @@ begin
const
newRow
=
document
.
createElement
(
'div'
);
newRow
.
className
=
'row mb-2'
;
// Labels and inputs
const
labels
=
[
'#'
,
'Color'
,
'LPI'
,
'Size'
];
const
values
=
[
num
,
Color
,
LPI
,
Size
];
labels
.
forEach
((
label
,
index
)
=>
{
...
...
@@ -400,7 +406,6 @@ begin
removeButtonCol
.
appendChild
(
removeButton
);
newRow
.
appendChild
(
removeButtonCol
);
// Add the new row to the container
container
.
appendChild
(
newRow
);
end
;
end
;
...
...
@@ -513,9 +518,34 @@ begin
end
;
procedure
TFOrderEntry
.
getCustomer
(
customerID
:
string
);
var
xdcResponse
:
TXDataClientResponse
;
customer
:
TJSObject
;
address
:
string
;
begin
xdcResponse
:=
await
(
XDataWebClient1
.
RawInvokeAsync
(
'ILookupService.GetCustomer'
,
[
customerID
]));
customer
:=
TJSObject
(
xdcResponse
.
Result
);
XDataWebDataSet1
.
Close
;
XDataWebDataSet1
.
SetJsonData
(
customer
);
XDataWebDataSet1
.
Open
;
xdwdsShipTo
.
Close
;
xdwdsShipTo
.
SetJSONData
(
customer
[
'ADDRESS_LIST'
]);
xdwdsShipTo
.
Open
;
console
.
log
(
xdwdsShipToADDRESS
.
AsString
);
console
.
log
(
customer
[
'ADDRESS_LIST'
]);
end
;
procedure
TFOrderEntry
.
WebFormShow
(
Sender
:
TObject
);
begin
getOrder
(
orderID
);
if
mode
<>
'ADD'
then
getOrder
(
orderID
)
else
getCustomer
(
customerID
);
console
.
log
(
customerID
);
HideNotification
();
end
;
...
...
kgOrdersClient/View.OrderList.dfm
View file @
7f19b291
...
...
@@ -31,21 +31,6 @@ object FOrderList: TFOrderList
HeightPercent = 100.000000000000000000
WidthPercent = 100.000000000000000000
end
object edtSearch: TWebEdit
Left = 8
Top = 384
Width = 121
Height = 22
HelpType = htKeyword
ChildOrder = 8
ElementClassName = 'form-control'
ElementID = 'edtsearch'
ElementFont = efCSS
HeightStyle = ssAuto
HeightPercent = 100.000000000000000000
HideSelection = False
WidthPercent = 100.000000000000000000
end
object pnlMessage: TWebPanel
Left = 370
Top = 558
...
...
@@ -58,7 +43,7 @@ object FOrderList: TFOrderList
ElementFont = efCSS
ElementPosition = epRelative
Role = 'alert'
TabOrder =
1
TabOrder =
0
object lblMessage: TWebLabel
Left = 28
Top = 9
...
...
@@ -89,40 +74,6 @@ object FOrderList: TFOrderList
WidthPercent = 100.000000000000000000
end
end
object tblOrders: TWebDBTableControl
Left = 0
Top = 142
Width = 1016
Height = 289
ElementClassName = 'table'
ElementId = 'tbl_orders'
BorderColor = clSilver
ChildOrder = 5
ColHeader = False
ElementTableClassName = 'table table-striped table-hover table-bordered'
Options.ResizeColumns = True
OnClickCell = tblOrdersClickCell
Columns = <
item
DataField = 'ID'
Title = 'ID'
Width = 24
end
item
DataField = 'NAME'
Title = 'NAME'
Width = 100
end
item
DataField = 'SHORT_NAME'
Title = 'SHORT_NAME'
end
item
DataField = 'ADDRESS'
Title = 'ADDRESS'
end>
DataSource = wdsCustomers
end
object cbCorrugatedPlate: TWebCheckBox
Left = 190
Top = 26
...
...
@@ -180,7 +131,211 @@ object FOrderList: TFOrderList
HeightPercent = 100.000000000000000000
Text = 'edtID'
WidthPercent = 100.000000000000000000
OnChange = edtIDChange
OnClick = btnConfirmClick
end
object btnFilter: TWebButton
Left = 564
Top = 195
Width = 96
Height = 25
Caption = 'Filter'
ChildOrder = 9
HeightPercent = 100.000000000000000000
WidthPercent = 100.000000000000000000
OnClick = btnFilterClick
end
object TMSFNCGrid1: TTMSFNCGrid
Left = 228
Top = 308
Width = 588
Height = 353
AdaptToStyle = True
ParentDoubleBuffered = False
DoubleBuffered = True
TabOrder = 7
DefaultRowHeight = 40.000000000000000000
FixedColumns = 0
ColumnCount = 0
RowCount = 1
Options.Bands.Enabled = True
Options.Editing.CalcFormat = '%g'
Options.Filtering.MultiColumn = True
Options.Grouping.CalcFormat = '%g'
Options.Grouping.GroupCountFormat = '(%d)'
Options.IO.XMLEncoding = 'ISO-8859-1'
Options.Mouse.ColumnSizing = True
Options.Mouse.ClickMargin = 0
Options.Mouse.ColumnSizeMargin = 6
Options.Mouse.RowSizing = True
Options.Mouse.RowSizeMargin = 6
Options.Mouse.FixedColumnSizing = True
Options.Mouse.FixedRowSizing = True
Columns = <
item
BorderWidth = 1
FixedFont.Charset = DEFAULT_CHARSET
FixedFont.Color = clWindowText
FixedFont.Height = -11
FixedFont.Name = 'Tahoma'
FixedFont.Style = []
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
Font.Height = -11
Font.Name = 'Tahoma'
Font.Style = []
ID = ''
Width = 68.000000000000000000
end
item
BorderWidth = 1
FixedFont.Charset = DEFAULT_CHARSET
FixedFont.Color = clWindowText
FixedFont.Height = -11
FixedFont.Name = 'Tahoma'
FixedFont.Style = []
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
Font.Height = -11
Font.Name = 'Tahoma'
Font.Style = []
ID = ''
Width = 68.000000000000000000
end
item
BorderWidth = 1
FixedFont.Charset = DEFAULT_CHARSET
FixedFont.Color = clWindowText
FixedFont.Height = -11
FixedFont.Name = 'Tahoma'
FixedFont.Style = []
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
Font.Height = -11
Font.Name = 'Tahoma'
Font.Style = []
ID = ''
Width = 68.000000000000000000
end
item
BorderWidth = 1
FixedFont.Charset = DEFAULT_CHARSET
FixedFont.Color = clWindowText
FixedFont.Height = -11
FixedFont.Name = 'Tahoma'
FixedFont.Style = []
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
Font.Height = -11
Font.Name = 'Tahoma'
Font.Style = []
ID = ''
Width = 68.000000000000000000
end
item
BorderWidth = 1
FixedFont.Charset = DEFAULT_CHARSET
FixedFont.Color = clWindowText
FixedFont.Height = -11
FixedFont.Name = 'Tahoma'
FixedFont.Style = []
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
Font.Height = -11
Font.Name = 'Tahoma'
Font.Style = []
ID = ''
Width = 68.000000000000000000
end>
DefaultFont.Charset = DEFAULT_CHARSET
DefaultFont.Color = clBlack
DefaultFont.Height = -11
DefaultFont.Name = 'Segoe UI'
DefaultFont.Style = []
Stroke.Color = 15987699
TopRow = 1
Appearance.FixedLayout.Fill.Kind = gfkGradient
Appearance.FixedLayout.Fill.Color = 16382457
Appearance.FixedLayout.Fill.ColorTo = 16382457
Appearance.FixedLayout.Stroke.Color = 15987699
Appearance.FixedLayout.Font.Charset = DEFAULT_CHARSET
Appearance.FixedLayout.Font.Color = clBlack
Appearance.FixedLayout.Font.Height = -11
Appearance.FixedLayout.Font.Name = 'Tahoma'
Appearance.FixedLayout.Font.Style = [fsBold]
Appearance.NormalLayout.Fill.Color = -1
Appearance.NormalLayout.Stroke.Color = 15987699
Appearance.NormalLayout.Font.Charset = DEFAULT_CHARSET
Appearance.NormalLayout.Font.Color = clBlack
Appearance.NormalLayout.Font.Height = -11
Appearance.NormalLayout.Font.Name = 'Tahoma'
Appearance.NormalLayout.Font.Style = []
Appearance.GroupLayout.Fill.Kind = gfkGradient
Appearance.GroupLayout.Fill.Color = 15385233
Appearance.GroupLayout.Fill.ColorTo = 15385233
Appearance.GroupLayout.Stroke.Color = 15987699
Appearance.GroupLayout.Font.Charset = DEFAULT_CHARSET
Appearance.GroupLayout.Font.Color = clBlack
Appearance.GroupLayout.Font.Height = -11
Appearance.GroupLayout.Font.Name = 'Tahoma'
Appearance.GroupLayout.Font.Style = []
Appearance.SummaryLayout.Fill.Kind = gfkGradient
Appearance.SummaryLayout.Fill.Color = 15385233
Appearance.SummaryLayout.Fill.ColorTo = 15385233
Appearance.SummaryLayout.Stroke.Color = 15987699
Appearance.SummaryLayout.Font.Charset = DEFAULT_CHARSET
Appearance.SummaryLayout.Font.Color = clBlack
Appearance.SummaryLayout.Font.Height = -11
Appearance.SummaryLayout.Font.Name = 'Tahoma'
Appearance.SummaryLayout.Font.Style = []
Appearance.SelectedLayout.Fill.Kind = gfkGradient
Appearance.SelectedLayout.Fill.Color = 15385233
Appearance.SelectedLayout.Fill.ColorTo = 15385233
Appearance.SelectedLayout.Stroke.Color = 15987699
Appearance.SelectedLayout.Font.Charset = DEFAULT_CHARSET
Appearance.SelectedLayout.Font.Color = clBlack
Appearance.SelectedLayout.Font.Height = -11
Appearance.SelectedLayout.Font.Name = 'Tahoma'
Appearance.SelectedLayout.Font.Style = []
Appearance.FocusedLayout.Fill.Kind = gfkGradient
Appearance.FocusedLayout.Fill.Color = 15385233
Appearance.FocusedLayout.Fill.ColorTo = 15385233
Appearance.FocusedLayout.Stroke.Color = 15987699
Appearance.FocusedLayout.Font.Charset = DEFAULT_CHARSET
Appearance.FocusedLayout.Font.Color = clBlack
Appearance.FocusedLayout.Font.Height = -11
Appearance.FocusedLayout.Font.Name = 'Tahoma'
Appearance.FocusedLayout.Font.Style = []
Appearance.FixedSelectedLayout.Fill.Kind = gfkGradient
Appearance.FixedSelectedLayout.Fill.Color = 15385233
Appearance.FixedSelectedLayout.Fill.ColorTo = 15385233
Appearance.FixedSelectedLayout.Stroke.Color = 15987699
Appearance.FixedSelectedLayout.Font.Charset = DEFAULT_CHARSET
Appearance.FixedSelectedLayout.Font.Color = clBlack
Appearance.FixedSelectedLayout.Font.Height = -11
Appearance.FixedSelectedLayout.Font.Name = 'Tahoma'
Appearance.FixedSelectedLayout.Font.Style = []
Appearance.BandLayout.Fill.Color = clLightyellow
Appearance.BandLayout.Stroke.Color = 15987699
Appearance.BandLayout.Font.Charset = DEFAULT_CHARSET
Appearance.BandLayout.Font.Color = clWindowText
Appearance.BandLayout.Font.Height = -11
Appearance.BandLayout.Font.Name = 'Tahoma'
Appearance.BandLayout.Font.Style = []
Appearance.ProgressLayout.Color = 15385233
Appearance.ProgressLayout.Format = '%.0f%%'
LeftCol = 0
ScrollMode = scmItemScrolling
DesignTimeSampleData = True
end
object edtSearch: TWebEdit
Left = 437
Top = 198
Width = 121
Height = 22
ChildOrder = 8
HeightPercent = 100.000000000000000000
WidthPercent = 100.000000000000000000
OnChange = edtSearchChange
end
object XDataWebClient1: TXDataWebClient
Connection = DMConnection.ApiConnection
...
...
kgOrdersClient/View.OrderList.pas
View file @
7f19b291
...
...
@@ -3,42 +3,48 @@ unit View.OrderList;
interface
uses
System
.
SysUtils
,
System
.
Generics
.
Collections
,
System
.
Classes
,
JS
,
Web
,
WEBLib
.
Graphics
,
WEBLib
.
Controls
,
WEBLib
.
Forms
,
WEBLib
.
Dialogs
,
WEBLib
.
Menus
,
WEBLib
.
ExtCtrls
,
WEBLib
.
StdCtrls
,
WEBLib
.
JSON
,
Auth
.
Service
,
XData
.
Web
.
Client
,
WebLib
.
Storage
,
ConnectionModule
,
App
.
Types
,
Vcl
.
StdCtrls
,
Vcl
.
Controls
,
WEBLib
.
DBCtrls
,
Data
.
DB
,
XData
.
Web
.
JsonDataset
,
XData
.
Web
.
Dataset
,
WEBLib
.
DB
,
WEBLib
.
Grids
,
Vcl
.
Grids
;
System
.
SysUtils
,
System
.
Classes
,
JS
,
Web
,
WEBLib
.
Graphics
,
WEBLib
.
Controls
,
WEBLib
.
Forms
,
WEBLib
.
Dialogs
,
WEBLib
.
StdCtrls
,
XData
.
Web
.
Client
,
WEBLib
.
ExtCtrls
,
Data
.
DB
,
XData
.
Web
.
Dataset
,
VCL
.
TMSFNCTypes
,
VCL
.
TMSFNCGrid
,
VCL
.
TMSFNCGridData
,
VCL
.
TMSFNCUtils
,
VCL
.
TMSFNCGraphics
,
VCL
.
TMSFNCGraphicsTypes
,
VCL
.
TMSFNCGridCell
,
VCL
.
TMSFNCGridOptions
,
VCL
.
TMSFNCCustomComponent
,
VCL
.
TMSFNCCustomGrid
,
VCL
.
TMSFNCGridDatabaseAdapter
,
VCL
.
TMSFNCCustomControl
,
VCL
.
TMSFNCCustomScrollControl
,
WEBLib
.
DB
,
XData
.
Web
.
JsonDataset
,
Vcl
.
StdCtrls
,
Vcl
.
Controls
,
ConnectionModule
;
type
TFOrderList
=
class
(
TWebForm
)
lblEntries
:
TWebLabel
;
lblEntries2
:
TWebLabel
;
edtSearch
:
TWebEdit
;
edtCompanyName
:
TWebEdit
;
edtID
:
TWebEdit
;
pnlMessage
:
TWebPanel
;
lblMessage
:
TWebLabel
;
btnCloseNotification
:
TWebButton
;
btnFilter
:
TWebButton
;
XDataWebClient1
:
TXDataWebClient
;
xdwdsCustomers
:
TXDataWebDataSet
;
wdsCustomers
:
TWebDataSource
;
xdwdsCustomers
:
TXDataWebDataSet
;
xdwdsCustomersID
:
TIntegerField
;
xdwdsCustomersNAME
:
TStringField
;
xdwdsCustomersSHORT_NAME
:
TStringField
;
xdwdsCustomersADDRESS
:
TStringField
;
tblOrders
:
TWebDBTableControl
;
TMSFNCGrid1
:
TTMSFNCGrid
;
btnConfirm
:
TWebButton
;
cbCorrugatedPlate
:
TWebCheckBox
;
cbWebPlate
:
TWebCheckBox
;
btnConfirm
:
TWebButton
;
edtCompanyName
:
TWebEdit
;
edtID
:
TWebEdit
;
procedure
edtIDChange
(
Sender
:
TObject
);
procedure
edtCompanyNameChange
(
Sender
:
TObject
);
procedure
tblOrdersClickCell
(
Sender
:
TObject
;
ACol
,
ARow
:
Integer
);
procedure
WebFormShow
(
Sender
:
TObject
)
;
procedure
btnFilterClick
(
Sender
:
TObject
)
;
procedure
cbCorrugatedPlateClick
(
Sender
:
TObject
)
;
procedure
cbWebPlateClick
(
Sender
:
TObject
);
procedure
btnConfirmClick
(
Sender
:
TObject
);
procedure
edtSearchChange
(
Sender
:
TObject
);
private
[
async
]
procedure
GetCustomers
;
procedure
FilterDataset
;
[
async
]
procedure
getCustomers
();
procedure
PopulateGridManually
;
procedure
ApplyFilter
;
public
class
function
CreateForm
(
AElementID
:
string
):
TWebForm
;
end
;
var
...
...
@@ -48,142 +54,128 @@ implementation
{$R *.dfm}
{ TFOrderList }
class
function
TFOrderList
.
CreateForm
(
AElementID
:
string
):
TWebForm
;
procedure
TFOrderList
.
WebFormShow
(
Sender
:
TObject
);
begin
Application
.
CreateForm
(
TFOrderList
,
AElementID
,
Result
,
procedure
(
AForm
:
TObject
)
begin
with
TFOrderList
(
AForm
)
do
begin
// Initialize or configure form properties as needed
console
.
log
(
'TFOrderList created and bound to ElementID:'
,
AElementID
);
GetCustomers
;
end
;
end
);
getCustomers
();
// Fetch and populate the grid with customer data
end
;
procedure
TFOrderList
.
edtCompanyNameChange
(
Sender
:
TObject
);
[
async
]
procedure
TFOrderList
.
getCustomers
();
var
xdcResponse
:
TXDataClientResponse
;
customerList
:
TJSObject
;
begin
// FilterDataset;
console
.
log
(
'Filtering data logic WIP'
);
end
;
// Fetch data from XData service
xdcResponse
:=
await
(
XDataWebClient1
.
RawInvokeAsync
(
'ILookupService.GetCustomers'
,
[])
);
customerList
:=
TJSObject
(
xdcResponse
.
Result
)
;
procedure
TFOrderList
.
edtIDChange
(
Sender
:
TObject
);
begin
// FilterDataset;
console
.
log
(
'Filtering data logic WIP'
);
// Load data into TXDataWebDataset
xdwdsCustomers
.
Close
;
xdwdsCustomers
.
SetJsonData
(
customerList
[
'data'
]);
xdwdsCustomers
.
Open
;
// Manually populate the grid
PopulateGridManually
;
end
;
procedure
TFOrderList
.
GetCustomers
;
procedure
TFOrderList
.
PopulateGridManually
;
var
xdcResponse
:
TXDataClientResponse
;
ResponseObject
:
TJSObject
;
DataArray
:
TJSArray
;
RowIndex
:
Integer
;
begin
TMSFNCGrid1
.
BeginUpdate
;
try
asm
startSpinner
();
end
;
// Fetch data from the server
xdcResponse
:=
await
(
XDataWebClient1
.
RawInvokeAsync
(
'ILookupService.GetCustomers'
,
[]));
TMSFNCGrid1
.
Clear
;
// Clear any existing data
// Log the raw JSON response to verify its structure
console
.
log
(
'Raw JSON Response:'
+
TJSJSON
.
stringify
(
xdcResponse
.
Result
));
// Set up column headers
TMSFNCGrid1
.
ColumnCount
:=
4
;
TMSFNCGrid1
.
RowCount
:=
1
;
TMSFNCGrid1
.
Cells
[
0
,
0
]
:=
'ID'
;
TMSFNCGrid1
.
Cells
[
1
,
0
]
:=
'Name'
;
TMSFNCGrid1
.
Cells
[
2
,
0
]
:=
'Short Name'
;
TMSFNCGrid1
.
Cells
[
3
,
0
]
:=
'Address'
;
//
Extract the "data" array from the JSON response
ResponseObject
:=
TJSObject
(
xdcResponse
.
Result
)
;
DataArray
:=
TJSArray
(
ResponseObject
[
'data'
])
;
//
Populate the grid with data from the dataset
xdwdsCustomers
.
First
;
RowIndex
:=
1
;
// Load the extracted array into the dataset
xdwdsCustomers
.
Close
;
xdwdsCustomers
.
SetJsonData
(
DataArray
);
xdwdsCustomers
.
Open
;
while
not
xdwdsCustomers
.
EOF
do
begin
TMSFNCGrid1
.
RowCount
:=
RowIndex
+
1
;
// Log record count and dataset status
console
.
log
(
'Dataset Record Count: '
+
IntToStr
(
xdwdsCustomers
.
RecordCount
));
TMSFNCGrid1
.
Cells
[
0
,
RowIndex
]
:=
xdwdsCustomers
.
FieldByName
(
'ID'
).
AsString
;
TMSFNCGrid1
.
Cells
[
1
,
RowIndex
]
:=
xdwdsCustomers
.
FieldByName
(
'NAME'
).
AsString
;
TMSFNCGrid1
.
Cells
[
2
,
RowIndex
]
:=
xdwdsCustomers
.
FieldByName
(
'SHORT_NAME'
).
AsString
;
TMSFNCGrid1
.
Cells
[
3
,
RowIndex
]
:=
xdwdsCustomers
.
FieldByName
(
'ADDRESS'
).
AsString
;
if
xdwdsCustomers
.
RecordCount
=
0
then
console
.
log
(
'Dataset is empty.'
)
else
console
.
log
(
'Dataset loaded successfully with records.'
);
finally
asm
setTimeout
(
endSpinner
,
2000
);
Inc
(
RowIndex
);
xdwdsCustomers
.
Next
;
end
;
// Auto-size columns
TMSFNCGrid1
.
AutoSizeColumns
;
finally
TMSFNCGrid1
.
EndUpdate
;
end
;
end
;
procedure
TFOrderList
.
ApplyFilter
;
var
fd
:
TTMSFNCGridFilterData
;
i
:
Integer
;
SearchText
:
string
;
begin
SearchText
:=
Trim
(
edtSearch
.
Text
);
// Remove any existing filters
TMSFNCGrid1
.
RemoveFilter
;
procedure
TFOrderList
.
tblOrdersClickCell
(
Sender
:
TObject
;
ACol
,
ARow
:
Integer
);
begin
asm
startSpinner
();
end
;
try
// Ensure the dataset is active and the row index is valid
if
xdwdsCustomers
.
Active
and
(
ARow
>=
0
)
and
(
ARow
<
xdwdsCustomers
.
RecordCount
)
then
begin
xdwdsCustomers
.
RecNo
:=
ARow
+
1
;
// Set the dataset to the selected row
// Populate the edit boxes with the dataset field values
edtCompanyName
.
Text
:=
xdwdsCustomers
.
FieldByName
(
'NAME'
).
AsString
;
edtID
.
Text
:=
xdwdsCustomers
.
FieldByName
(
'ID'
).
AsString
;
TMSFNCGrid1
.
Filter
.
Clear
;
console
.
log
(
'Row clicked: ARow='
+
IntToStr
(
ARow
)
+
', Company='
+
edtCompanyName
.
Text
+
', ID='
+
edtID
.
Text
);
end
;
finally
asm
setTimeout
(
endSpinner
,
2000
);
end
;
// Add a filter for each column
for
i
:=
0
to
TMSFNCGrid1
.
ColumnCount
-
1
do
begin
fd
:=
TMSFNCGrid1
.
Filter
.
Add
;
fd
.
Column
:=
i
;
fd
.
Condition
:=
'*'
+
SearchText
+
'*'
;
// Match text anywhere in the cell
fd
.
CaseSensitive
:=
False
;
// Make the filter case-insensitive
// Use foOR for "match any column" logic
if
i
>
0
then
fd
.
Operation
:=
foOR
else
fd
.
Operation
:=
foNONE
;
// First filter has no logical operation
end
;
end
;
// Apply the filters to the grid
TMSFNCGrid1
.
ApplyFilter
;
end
;
procedure
TFOrderList
.
FilterDataset
;
var
FilterTextCompany
,
FilterTextID
:
string
;
FilterCondition
:
string
;
procedure
TFOrderList
.
btnFilterClick
(
Sender
:
TObject
);
begin
try
// Get the current filter inputs
FilterTextCompany
:=
Trim
(
edtCompanyName
.
Text
);
FilterTextID
:=
Trim
(
edtID
.
Text
);
// Build the filter condition
FilterCondition
:=
''
;
if
FilterTextCompany
<>
''
then
FilterCondition
:=
Format
(
'NAME LIKE ''%%%s%%'''
,
[
FilterTextCompany
]);
if
FilterTextID
<>
''
then
begin
if
FilterCondition
<>
''
then
FilterCondition
:=
FilterCondition
+
' AND '
;
FilterCondition
:=
FilterCondition
+
Format
(
'ID LIKE ''%%%s%%'''
,
[
FilterTextID
]);
end
;
ApplyFilter
;
end
;
// Apply the filter condition
xdwdsCustomers
.
Filtered
:=
False
;
// Disable existing filter
xdwdsCustomers
.
Filter
:=
FilterCondition
;
// Set new filter
xdwdsCustomers
.
Filtered
:=
True
;
// Enable filtering
procedure
TFOrderList
.
edtIDChange
(
Sender
:
TObject
);
begin
cbWebPlate
.
Checked
:=
False
;
end
;
console
.
log
(
'Filter applied:'
,
FilterCondition
);
procedure
TFOrderList
.
cbWebPlateClick
(
Sender
:
TObject
);
begin
cbCorrugatedPlate
.
Checked
:=
False
;
end
;
except
on
E
:
Exception
do
begin
// Handle any errors gracefully
console
.
error
(
'Error applying filter:'
,
E
.
Message
);
ShowMessage
(
'An error occurred while applying the filter. Please check your input.'
);
end
;
end
;
procedure
TFOrderList
.
btnConfirmClick
(
Sender
:
TObject
);
begin
Close
;
end
;
procedure
TFOrderList
.
edtSearchChange
(
Sender
:
TObject
);
begin
ApplyFilter
;
end
;
end
.
kgOrdersClient/View.Orders.pas
View file @
7f19b291
...
...
@@ -79,7 +79,7 @@ type
procedure
ClearTable
();
procedure
GeneratePagination
(
TotalPages
:
Integer
);
function
GenerateSearchOptions
():
string
;
procedure
orderEntry
(
orderInfo
,
mode
:
string
);
procedure
orderEntry
(
orderInfo
,
customerInfo
,
mode
:
string
);
procedure
HideNotification
();
procedure
ShowNotification
(
Notification
:
string
);
procedure
ShowOrderListForm
();
...
...
@@ -183,9 +183,16 @@ begin
// Create the order list form, passing the ElementID
TFOrderList
.
CreateForm
(
pnlOrders
.
ElementID
);
// Show the panel after the form is created
if
Assigned
(
OrdersPanel
)
then
OrdersPanel
.
style
.
setProperty
(
'display'
,
'block'
);
// used to manage Back button handling to close subform
window
.
location
.
hash
:=
'subform'
;
newform
.
ShowModal
(
procedure
(
AValue
:
TModalResult
)
begin
if
newForm
.
edtID
.
Text
<>
''
then
orderEntry
(
''
,
newForm
.
edtID
.
Text
,
'ADD'
);
end
);
end
;
...
...
@@ -212,7 +219,7 @@ begin
NewRow
.
Attrs
[
'orderType'
]
:=
XDataWebDataSet1orderType
.
Value
;
NewRow
.
addEventListener
(
'click'
,
procedure
begin
orderEntry
(
NewRow
.
Attrs
[
'id'
],
'EDIT'
);
orderEntry
(
NewRow
.
Attrs
[
'id'
],
'
'
,
'
EDIT'
);
end
);
// Order ID Cell
...
...
@@ -648,9 +655,9 @@ begin
ShowOrderListForm
();
end
;
procedure
TFViewOrders
.
orderEntry
(
orderInfo
,
mode
:
string
);
procedure
TFViewOrders
.
orderEntry
(
orderInfo
,
customerInfo
,
mode
:
string
);
begin
FViewMain
.
ViewOrderEntry
(
orderInfo
,
mode
);
FViewMain
.
ViewOrderEntry
(
orderInfo
,
customerInfo
,
mode
);
end
;
procedure
TFViewOrders
.
btnApplyClick
(
Sender
:
TObject
);
...
...
@@ -677,7 +684,7 @@ end;
procedure
TFViewOrders
.
btnConfirmClick
(
Sender
:
TObject
);
begin
orderEntry
(
''
,
'ADD'
);
//
orderEntry('', 'ADD');
end
;
procedure
TFViewOrders
.
btnFiltersClick
(
Sender
:
TObject
);
...
...
kgOrdersClient/template/css/app.css
View file @
7f19b291
...
...
@@ -7,7 +7,12 @@
background-color
:
#fff
;
}
input
[
type
=
"text"
]
{
min-width
:
50px
;
max-width
:
100%
;
width
:
auto
;
padding-left
:
5px
;
}
.card-header
{
width
:
100%
;
...
...
kgOrdersServer/Source/Auth.Database.dfm
View file @
7f19b291
...
...
@@ -22,7 +22,6 @@ object AuthDatabase: TAuthDatabase
SpecificOptions.Strings = (
'PostgreSQL.Schema=envoy')
Username = 'root'
Server = '192.168.75.133'
LoginPrompt = False
Left = 69
Top = 131
...
...
kgOrdersServer/Source/Database.dfm
View file @
7f19b291
...
...
@@ -8,7 +8,6 @@ object FDatabaseModule: TFDatabaseModule
SpecificOptions.Strings = (
'PostgreSQL.Schema=envoy')
Username = 'root'
Server = '192.168.75.133'
LoginPrompt = False
Left = 75
Top = 139
...
...
kgOrdersServer/Source/Lookup.Service.pas
View file @
7f19b291
...
...
@@ -84,12 +84,18 @@ type
data
:
TList
<
TOrderItem
>;
end
;
TAddressItem
=
class
Public
ADDRESS
:
string
;
end
;
TCustomerItem
=
class
Public
NAME
:
string
;
ID
:
integer
;
SHORT_NAME
:
string
;
ADDRESS
:
string
;
staff_fields_invoice_to
:
string
;
ADDRESS_LIST
:
TList
<
TAddressItem
>;
end
;
TCustomerList
=
class
...
...
@@ -202,6 +208,7 @@ type
[
HttpGet
]
function
GetOrders
(
searchOptions
:
string
):
TOrderList
;
[
HttpGet
]
function
GetOrder
(
orderInfo
:
string
):
TFullOrder
;
[
HttpGet
]
function
GetCustomers
():
TCustomerList
;
[
HttpGet
]
function
GetCustomer
(
ID
:
string
):
TCustomerItem
;
function
AddUser
(
userInfo
:
string
):
string
;
function
AddItem
(
itemInfo
:
string
):
string
;
...
...
kgOrdersServer/Source/Lookup.ServiceImpl.pas
View file @
7f19b291
...
...
@@ -26,6 +26,7 @@ type
function
GetOrders
(
searchOptions
:
string
):
TOrderList
;
function
GetOrder
(
orderInfo
:
string
):
TFullOrder
;
function
GetCustomers
():
TCustomerList
;
function
GetCustomer
(
ID
:
string
):
TCustomerItem
;
function
EditUser
(
const
editOptions
:
string
):
string
;
function
Search
(
phoneNum
:
string
):
TOrderList
;
function
AddUser
(
userInfo
:
string
):
string
;
...
...
@@ -80,7 +81,7 @@ begin
customer
.
NAME
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'NAME'
).
AsString
;
customer
.
ID
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'CUSTOMER_ID'
).
AsInteger
;
customer
.
SHORT_NAME
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'SHORT_NAME'
).
AsString
;
customer
.
ADDRESs
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'BILL_ADDRESS'
).
AsString
+
customer
.
staff_fields_invoice_to
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'BILL_ADDRESS'
).
AsString
+
', '
+
ordersDB
.
UniQuery1
.
FieldByName
(
'BILL_CITY'
).
AsString
+
' '
+
ordersDB
.
UniQuery1
.
FieldByName
(
'BILL_ZIP'
).
AsString
;
result
.
data
.
Add
(
customer
);
...
...
@@ -90,6 +91,35 @@ begin
ordersDB
.
UniQuery1
.
Close
;
end
;
function
TLookupService
.
GetCustomer
(
ID
:
string
):
TCustomerItem
;
var
SQL
:
string
;
ADDRESS
:
TAddressItem
;
begin
SQL
:=
'SELECT c.NAME, c.SHORT_NAME, c.BILL_ADDRESS_BLOCK, s.ship_block FROM customers c JOIN customers_ship s ON c.CUSTOMER_ID = s.customer_id WHERE c.CUSTOMER_ID = '
+
ID
;
doQuery
(
ordersDB
.
UniQuery1
,
SQL
);
result
:=
TCustomerItem
.
Create
;
result
.
ADDRESS_LIST
:=
TList
<
TAddressItem
>.
Create
;
TXDataOperationContext
.
Current
.
Handler
.
ManagedObjects
.
Add
(
Result
.
ADDRESS_LIST
);
result
.
NAME
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'NAME'
).
AsString
;
result
.
ID
:=
StrToInt
(
ID
);
result
.
SHORT_NAME
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'SHORT_NAME'
).
AsString
;
result
.
staff_fields_invoice_to
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'BILL_ADDRESS_BLOCK'
).
AsString
;
while
not
ordersDB
.
UniQuery1
.
Eof
do
begin
ADDRESS
:=
TAddressItem
.
Create
;
TXDataOperationContext
.
Current
.
Handler
.
ManagedObjects
.
Add
(
ADDRESS
);
ADDRESS
.
ADDRESS
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'ship_block'
).
AsString
;
result
.
ADDRESS_LIST
.
Add
(
ADDRESS
);
ordersDB
.
UniQuery1
.
Next
;
end
;
ordersDB
.
UniQuery1
.
Close
;
end
;
function
TLookupService
.
Search
(
phoneNum
:
string
):
TOrderList
;
// Searchs the database for a specific from phone number then returns a list of
// calls from said number
...
...
kgOrdersServer/kgOrdersServer.ini
View file @
7f19b291
[Options]
LogFileNum
=
2
26
LogFileNum
=
2
34
UpdateTimerLength
=
0
[Database]
--Server
=
192.168.159.132
--Server
=
192.168.102.129
Server
=
192.168.
75.133
Server
=
192.168.
102.130
[Twilio]
AccountSID
=
AC37aeef9c36a2cccbaecbadafc172b2ff
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment