Subversion Repositories wimsdev

Rev

Rev 8155 | Rev 9007 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
10 reyssat 1
/*    Copyright (C) 1998-2003 XIAO, Gang of Universite de Nice - Sophia Antipolis
2
 *
3
 *  This program is free software; you can redistribute it and/or modify
4
 *  it under the terms of the GNU General Public License as published by
5
 *  the Free Software Foundation; either version 2 of the License, or
6
 *  (at your option) any later version.
7
 *
8
 *  This program is distributed in the hope that it will be useful,
9
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
10
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
 *  GNU General Public License for more details.
12
 *
13
 *  You should have received a copy of the GNU General Public License
14
 *  along with this program; if not, write to the Free Software
15
 *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
16
 */
17
 
7673 bpr 18
/* html form simplification routines */
8185 bpr 19
#include "wims.h"
10 reyssat 20
 
21
#define MAX_MENU_ITEMS 256
22
 
23
enum {
24
    FORM_SELECT, FORM_RADIO, FORM_BAR, FORM_CHECKBOX
25
};
26
 
7673 bpr 27
/* Produces <select> and <option>s.
28
 * Parameter string: name from n1 to n2 [prompt plist]
29
 * or name, list slist [prompt plist]
8155 bpr 30
 * Using script to do this is too slow.
31
 */
10 reyssat 32
void _form_menus(char *p,int kind)
33
{
7515 bpr 34
    char *n, *li, *pp, *val, *p0, *p1, *p2, *pc, *s, *pfre="";
10 reyssat 35
    char *vlist[MAX_MENU_ITEMS], *plist[MAX_MENU_ITEMS];
36
    char nbuf[MAX_LINELEN+1],vbuf[MAX_LINELEN+1],pbuf[MAX_LINELEN+1];
7515 bpr 37
    char buf[256], pfrb[256];
10 reyssat 38
    int i,i1=0,i2,itemcnt,type;
39
    if(!outputing) return;
40
    n=find_word_start(p); if(*n==0) return;
41
    pp=find_word_end(n);
42
    if(*pp!=0) *(pp++)=0;
43
    else {
7673 bpr 44
      syntax: module_error("syntax_error"); return;
10 reyssat 45
    }
46
    li=find_word_start(pp); pp=find_word_end(li);
47
    if(*pp!=0) *(pp++)=0; else goto syntax;
48
    itemcnt=0;
49
    if(strcmp(li,"from")==0) {
7673 bpr 50
      p1=find_word_start(pp);
51
      p2=wordchr(p1,"to"); if(p2==NULL || p2<=p1) goto syntax;
52
      *(p2-1)=0; p2=find_word_start(p2+strlen("to"));
53
      pp=wordchr(p2,"prompt"); if(pp!=NULL) *(pp-1)=0;
54
      i1=evalue(p1); i2=evalue(p2);
55
      if(i1<-100000000 || i1>100000000 || i2<-100000000 || i2>100000000)
56
        goto syntax;
57
      if(i2<i1) return;
58
      if(i2>i1+MAX_MENU_ITEMS-1) i2=i1+MAX_MENU_ITEMS-1;
59
      itemcnt=i2-i1+1;
60
      type=0;
10 reyssat 61
    }
62
    else {
7673 bpr 63
      if(strcmp(li,"list")==0) {
64
         p1=find_word_start(pp);
65
         pp=wordchr(p1,"prompt"); if(pp!=NULL && pp>p1) *(pp-1)=0;
66
         ovlstrcpy(vbuf,p1);substit(vbuf);
67
         itemcnt=cutitems(vbuf,vlist,MAX_MENU_ITEMS);
68
         type=1;
69
      }
70
      else goto syntax;
10 reyssat 71
    }
72
    for(i=0;i<itemcnt;i++) plist[i]=NULL;
73
    if(pp!=NULL) {
7673 bpr 74
      p1=find_word_start(pp+strlen("prompt"));
75
      ovlstrcpy(pbuf,p1);substit(pbuf);
76
      cutitems(pbuf,plist,MAX_MENU_ITEMS);
10 reyssat 77
    }
3718 reyssat 78
    ovlstrcpy(nbuf,n);substit(nbuf);
10 reyssat 79
    if(kind==FORM_SELECT) {
7673 bpr 80
      char *pp;
81
      pp=getvar("wims_formselect_switch"); if(pp==NULL) pp="";
82
      output("<select %s name=\"%s\" id=\"%s\">\n",pp,nbuf,nbuf);
10 reyssat 83
    }
7515 bpr 84
    if(kind==FORM_BAR) {
85
      s=getvar("wims_ref_class");
86
      if(s!=NULL && *s!=0 && !isspace(*s)) {
87
       snprintf(pfrb,sizeof(pfrb)," <span class=\"%s\">",s); pfre="</span>";
88
      } else { pfrb[0]=0; pfre=""; }
89
      output("%s<span style=\"font-weight:bold;\">-</span>",pfrb);
90
    }
10 reyssat 91
    val=getvar(nbuf);if(val==NULL) val="";
92
    for(i=0;i<itemcnt;i++) {
7673 bpr 93
      if(type==0) {
94
         snprintf(buf,sizeof(buf),"%d",i+i1);
95
         p0=buf;
96
      }
97
      else p0=vlist[i];
98
      if(*find_word_start(p0)==0) continue;
99
      if(plist[i]==NULL) plist[i]=p0;
100
      if(*val!=0 &&
101
        (strcmp(p0,val)==0 ||
102
         ( (kind==FORM_SELECT || kind==FORM_CHECKBOX)
103
          && itemchr(val,p0)!=NULL))) {
104
         if(kind==FORM_SELECT) pc=" selected=\"selected\"";
105
         else pc=" checked=\"checked\"";
106
      }
107
      else pc="";
108
      s=getvar("wims_ref_class");
7515 bpr 109
     if(s!=NULL && *s!=0 && !isspace(*s)) {
110
       snprintf(pfrb,sizeof(pfrb)," <span class=\"%s\">",s); pfre="</span>";
111
     }
112
     else { pfrb[0]=0; pfre=""; }
7673 bpr 113
      switch(kind) {
114
         case FORM_SELECT:
115
         output("<option value=\"%s\"%s>%s</option>\n",p0,pc,plist[i]);
116
         break;
7515 bpr 117
 
7673 bpr 118
         case FORM_RADIO:
119
         output("%s<input type=\"radio\" name=\"%s\" id=\"%s%d\" value=\"%s\"%s/><label for=\"%s%d\">%s</label>%s",
120
             pfrb,nbuf,nbuf,i,p0,pc,nbuf,i,plist[i],pfre);
121
         if(i<itemcnt-1 && itemcnt>2) _output_(",");
122
         _output_("\n");
123
         break;
7515 bpr 124
 
7673 bpr 125
         case FORM_CHECKBOX:
126
         output("%s<input type=\"checkbox\" name=\"%s\" id=\"%s%d\" value=\"%s\"%s/><label for=\"%s%d\">%s</label>%s",
127
             pfrb,nbuf,nbuf,i,p0,pc,nbuf,i,plist[i],pfre);
128
         if(i<itemcnt-1 && itemcnt>2) _output_(",");
129
         _output_("\n");
130
         break;
7515 bpr 131
 
7673 bpr 132
         case FORM_BAR:
133
         output("<input type=\"radio\" name=\"%s\" id=\"%s%d\" value=\"%s\"%s/>",
134
             nbuf,nbuf,i,p0,pc);
135
         break;
7515 bpr 136
 
7673 bpr 137
      }
10 reyssat 138
    }
7515 bpr 139
    setvar("wims_formradio_class","");
10 reyssat 140
    if(kind==FORM_SELECT) _output_("</select>");
7515 bpr 141
    if(kind==FORM_BAR) output("<span style=\"font-weight:bold;\">+</span>%s",pfre);
10 reyssat 142
}
143
 
144
void exec_formselect(char *p)
145
{
146
    _form_menus(p,FORM_SELECT);
147
}
148
 
149
void exec_formradio(char *p)
150
{
151
    _form_menus(p,FORM_RADIO);
152
}
153
 
154
void exec_formcheckbox(char *p)
155
{
156
    _form_menus(p,FORM_CHECKBOX);
157
}
158
 
159
void exec_formbar(char *p)
160
{
161
    _form_menus(p,FORM_BAR);
162
}
163