+
+ difference(){
+ union(){
+ cube([50, wallthick, 50]);
+ translate(sw_ctr)
+ rotate([0,0,90])
+ S1930_Positive();
+ }
+
+ translate(sw_ctr) {
+ rotate([0,0,90])
+ S1930_Negative();
+ }
+ }
+}
+
+ts_totx = 30;
+ts_toty = 25;
+ts_totz_inner = 8;
+
+ts_box_sz = [ts_totx, ts_toty, ts_totz_inner];
+
+$sealingbox_wallth = wallthick;
+$sealingbox_floorth = wallthick;
+$sealingbox_ceilth = wallthick;
+
+module TestSealBox(){ ////toplevel
+ $sealingbox_sz = ts_box_sz;
+
+ SealingBox_RectBox();
+ ts_cidoff = ($sealingbox_cnrrad * (1-.7) + wallthick * .8) * [1,1];
+ translate(ts_cidoff)
+ Commitid_BestCount([ts_totx,ts_toty] - 2*ts_cidoff);
+}
+
+module TestSealLid(){ ////toplevel
+ $sealingbox_sz = ts_box_sz;
+
+ difference(){
+ SealingBox_RectLid();
+
+ translate([ts_totx * .75, ts_toty/2, 0])
+ cylinder(h=100, r=5);
+
+ translate([-wallthick + $sealingbox_cnrrad*.5,
+ $sealingbox_cnrrad*.5 - wallthick,
+ ts_totz_inner + $sealingbox_ceilth])
+ Commitid_BestCount([ts_totx * .75 - 2.5 - ($sealingbox_cnrrad*.5),
+ ts_toty - ($sealingbox_cnrrad*.5 - wallthick)*2]);
+ }
+}
+
+module TestSealLidPrint(){ ////toplevel
+ rotate([180,0,0]) TestSealLid();
+}
+
+module ProfileDemos(){ ////toplevel
+ $sealingbox_sz = ts_box_sz;
+
+ SealingBox_WallProfile();
+ color("blue") SealingBox_FloorProfile();
+ SealingBox_LidProfile();
+ color("blue") SealingBox_CeilProfile();
+ color("red") translate([-5,0]) square([1,ts_totz_inner]);
+}
+
+module AtGlands(){
+ for (dgy=[-15,-45]) {
+ translate([totx_inner + wallthick - $sealingbox_cnrrad * .3,
+ toty_inner + dgy,
+ totz_inner/2])
+ children();
+ }
+}
+
+module Box(){ ////toplevel
+ $sealingbox_sz = sb_box_sz;
+
+ chargingconn_x = pxp6012_rad_outer + 1 + $sealingbox_cnrrad;
+ switch_x = chargingconn_x + pxp6012_rad_outer
+ + s1930_y_outer/2 + s1930_around;
+
+ strap_x_tot = strap_w + strap_pillar*2;
+
+ difference(){
+ union(){
+ rotate([90,0,0])
+ translate([-wallthick,-wallthick, -toty_inner])
+ SealingBox_RectBox();
+
+ translate([switch_x, toty_inner, totz_inner/2])
+ rotate([90,0,90])
+ S1930_Positive();
+
+ // keepers for lipo
+ for (kx= [ 40, 80, 120 ]) {
+ translate([kx, 40, -1])
+ cube([10, 5, 8 +1]);
+ }
+
+ AtGlands()
+ GlandPositive(cabledia);
+ }
+
+ // charging connector
+ translate([chargingconn_x,
+ toty_inner - (pxp6012_rad_outer + 5),
+ 10])
+ cylinder(r= pxp6012_rad, h= totz_outer);
+
+ translate([switch_x, toty_inner, totz_inner/2])
+ rotate([90,0,90])
+ S1930_Negative();
+
+ AtGlands()
+ GlandNegative(cabledia);
+ }
+}
+
+module BoxPrint(){ ////toplevel
+ rotate([-90,0,0])
+ Box();