diff --git a/logicaldoc-gui/antrun.xml b/logicaldoc-gui/antrun.xml
new file mode 100644
index 000000000..07ca31be2
--- /dev/null
+++ b/logicaldoc-gui/antrun.xml
@@ -0,0 +1,98 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Processing skin @{skin} for module @{module}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/logicaldoc-gui/pom.xml b/logicaldoc-gui/pom.xml
index fbab2bbb3..4e50c8f1a 100644
--- a/logicaldoc-gui/pom.xml
+++ b/logicaldoc-gui/pom.xml
@@ -338,186 +338,26 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+ ant-contrib
+ ant-contrib
+ 1.0b3
+
+
+ ant
+ ant
+
+
+
+
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/Common.gwt.xml b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/Common.gwt.xml
deleted file mode 100644
index 4f7e83d04..000000000
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/Common.gwt.xml
+++ /dev/null
@@ -1,19 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/Feature.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/Feature.java
index 748d9f623..2d9a2a318 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/Feature.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/Feature.java
@@ -220,6 +220,8 @@ public class Feature {
public static final int CHATGPT = 104;
public static final int GOOGLE_CALENDAR = 105;
+
+ public static final int SCANNER = 106;
public static final int ONLYOFFICE = 107;
@@ -264,8 +266,4 @@ public static boolean showDisabled() {
public static boolean showLicensee() {
return enabled(SHOW_DISABLED);
}
-
- public static boolean isCommercial() {
- return enabled(ADDITIONAL_FORMATS);
- }
}
\ No newline at end of file
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/AwesomeFactory.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/AwesomeFactory.java
index 98268d080..70321f579 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/AwesomeFactory.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/AwesomeFactory.java
@@ -149,10 +149,10 @@ public static String getIconHtml(String icon) {
public static String getSpinnerIconHtml(String icon, String text) {
if (text == null || text.isEmpty())
- return I_CLASS + getCssClassPrefix() + " fa-" + icon + " fa-lg fa-spinner' aria-hidden='true'>";
+ return I_CLASS + getCssClassPrefix() + " fa-" + icon + " fa-thin fa-spinner' aria-hidden='true'>";
else
return DIV_I_CLASS + getCssClassPrefix() + " fa-" + icon
- + " fa-lg fa-fw fa-spinner' aria-hidden='true'> " + I18N.message(text) + CLOSE_DIV;
+ + " fa-thin fa-fw fa-spinner' aria-hidden='true'> " + I18N.message(text) + CLOSE_DIV;
}
public static String getIconButtonHTML(String icon, String text, String tooltip, String color, String url) {
@@ -217,10 +217,15 @@ public static String getIndexedIcon(Integer indexed) {
return "";
String html = AwesomeFactory.getIconHtml("database");
if (indexed == Constants.INDEX_SKIP) {
+// html = "";
+// html += I_CLASS + AwesomeFactory.getCssClassPrefix()
+// + " fa-times fa-stack-1x' style='color: red' data-fa-transform='grow-2'>";
+
html = "";
+ + " fa-database fa-stack-1x fa-thin' aria-hidden='true' >";
html += I_CLASS + AwesomeFactory.getCssClassPrefix()
- + " fa-times fa-stack-1x' style='color: red' data-fa-transform='grow-2'>";
+ + " fa-times fa-stack-1x' style='color: red' >";
}
return html;
}
@@ -236,18 +241,18 @@ public static String getColoredIconHtml(String icon, String text, String color)
public static String getIconHtml(String icon, String rotation, String text) {
if (text == null || text.isEmpty())
return I_CLASS + getCssClassPrefix() + " fa-" + icon + (rotation != null ? " " + rotation : "")
- + " fa-lg' aria-hidden='true'>";
+ + " fa-thin' aria-hidden='true'>";
else
return DIV_I_CLASS + getCssClassPrefix() + " fa-" + icon + (rotation != null ? " " + rotation : "")
- + " fa-lg fa-fw' aria-hidden='true'> " + I18N.message(text) + CLOSE_DIV;
+ + " fa-thin fa-fw' aria-hidden='true'> " + I18N.message(text) + CLOSE_DIV;
}
public static String getColoredIconHtmlWithoutI18N(String icon, String text, String color) {
if (text == null || text.isEmpty())
- return I_CLASS + getCssClassPrefix() + " fa-" + icon + " fa-lg' aria-hidden='true' "
+ return I_CLASS + getCssClassPrefix() + " fa-" + icon + " fa-thin' aria-hidden='true' "
+ (color != null && !color.isEmpty() ? "style='color: " + color + "'" : "") + ">";
else
- return DIV_I_CLASS + getCssClassPrefix() + " fa-" + icon + " fa-lg fa-fw' aria-hidden='true'"
+ return DIV_I_CLASS + getCssClassPrefix() + " fa-" + icon + " fa-thin fa-fw' aria-hidden='true'"
+ (color != null && !color.isEmpty() ? "style='color: " + color + "'" : "") + "> " + text
+ CLOSE_DIV;
}
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/DocUtil.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/DocUtil.java
index 8c1424654..1503e0e39 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/DocUtil.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/DocUtil.java
@@ -159,11 +159,11 @@ public static String getFolderIcon(boolean open, int type, String name, String c
html = AwesomeFactory.getColoredIconHtmlWithoutI18N("cube", name, color);
else if (type == GUIFolder.TYPE_ALIAS) {
html = "
";
- html += "";
// This is the small alias arrow
- html += " ";
+ html += " ";
html += name + "
";
} else {
if (open)
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/ItemFactory.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/ItemFactory.java
index 6569c175a..d5406c331 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/ItemFactory.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/ItemFactory.java
@@ -97,7 +97,6 @@
import com.smartgwt.client.widgets.form.fields.MiniDateRangeItem;
import com.smartgwt.client.widgets.form.fields.MultiComboBoxItem;
import com.smartgwt.client.widgets.form.fields.PasswordItem;
-import com.smartgwt.client.widgets.form.fields.PickerIcon;
import com.smartgwt.client.widgets.form.fields.RadioGroupItem;
import com.smartgwt.client.widgets.form.fields.RichTextItem;
import com.smartgwt.client.widgets.form.fields.RowSpacerItem;
@@ -112,7 +111,6 @@
import com.smartgwt.client.widgets.form.fields.events.ChangedHandler;
import com.smartgwt.client.widgets.form.fields.events.EditorEnterEvent;
import com.smartgwt.client.widgets.form.fields.events.EditorExitEvent;
-import com.smartgwt.client.widgets.form.fields.events.FormItemIconClickEvent;
import com.smartgwt.client.widgets.form.validator.CustomValidator;
import com.smartgwt.client.widgets.form.validator.IntegerRangeValidator;
import com.smartgwt.client.widgets.form.validator.IsFloatValidator;
@@ -128,6 +126,8 @@
*/
public class ItemFactory {
+ public static final int ITEM_ICON_SIZE = 14;
+
private static final String PROTOCOL = "protocol";
private static final String LEVEL = "level";
@@ -211,6 +211,9 @@ public class ItemFactory {
dateRangeItem.setHintStyle("hint");
dateRangeItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
dateRangeItem.setBrowserSpellCheck(false);
+ dateRangeItem.setIconHeight(ITEM_ICON_SIZE);
+ dateRangeItem.setIconWidth(ITEM_ICON_SIZE);
+ dateRangeItem.setIconVAlign(VerticalAlignment.CENTER);
DateRangeItem.setDefaultProperties(dateRangeItem);
MiniDateRangeItem miniDateRangeItem = new MiniDateRangeItem();
@@ -225,6 +228,9 @@ public class ItemFactory {
miniDateRangeItem.setPickerIconPrompt(I18N.message(SHOWDATECHOOSER));
miniDateRangeItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
miniDateRangeItem.setBrowserSpellCheck(false);
+ miniDateRangeItem.setIconHeight(ITEM_ICON_SIZE);
+ miniDateRangeItem.setIconWidth(ITEM_ICON_SIZE);
+ miniDateRangeItem.setIconVAlign(VerticalAlignment.CENTER);
MiniDateRangeItem.setDefaultProperties(miniDateRangeItem);
DateItem dateItem = new DateItem();
@@ -239,10 +245,13 @@ public class ItemFactory {
dateItem.setEndDate(new Date(new Date().getTime() + 2208992400000L));
dateItem.setStartDate(new Date(-2208992400000L));
dateItem.setBrowserSpellCheck(false);
+ dateItem.setIconHeight(ITEM_ICON_SIZE);
+ dateItem.setIconWidth(ITEM_ICON_SIZE);
+ dateItem.setIconVAlign(VerticalAlignment.CENTER);
DateItem.setDefaultProperties(dateItem);
DateChooser dateChooser = new DateChooser();
- dateChooser.setEndYear(2040);
+ dateChooser.setEndYear(2050);
dateChooser.setStartYear(1990);
DateChooser.setDefaultProperties(dateChooser);
@@ -251,6 +260,9 @@ public class ItemFactory {
selectItem.setHintStyle("hint");
selectItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
selectItem.setBrowserSpellCheck(false);
+ selectItem.setIconHeight(ITEM_ICON_SIZE);
+ selectItem.setIconWidth(ITEM_ICON_SIZE);
+ selectItem.setIconVAlign(VerticalAlignment.CENTER);
SelectItem.setDefaultProperties(selectItem);
TextItem textItem = new TextItem();
@@ -258,24 +270,36 @@ public class ItemFactory {
textItem.setWidth(150);
textItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
textItem.setBrowserSpellCheck(false);
+ textItem.setIconHeight(ITEM_ICON_SIZE);
+ textItem.setIconWidth(ITEM_ICON_SIZE);
+ textItem.setIconVAlign(VerticalAlignment.CENTER);
TextItem.setDefaultProperties(textItem);
RadioGroupItem radioGroupItem = new RadioGroupItem();
radioGroupItem.setHintStyle("hint");
radioGroupItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
radioGroupItem.setBrowserSpellCheck(false);
+ radioGroupItem.setIconHeight(ITEM_ICON_SIZE);
+ radioGroupItem.setIconWidth(ITEM_ICON_SIZE);
+ radioGroupItem.setIconVAlign(VerticalAlignment.CENTER);
RadioGroupItem.setDefaultProperties(radioGroupItem);
CheckboxItem checkboxItem = new CheckboxItem();
checkboxItem.setHintStyle("hint");
checkboxItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
checkboxItem.setBrowserSpellCheck(false);
+ checkboxItem.setIconHeight(ITEM_ICON_SIZE);
+ checkboxItem.setIconWidth(ITEM_ICON_SIZE);
+ checkboxItem.setIconVAlign(VerticalAlignment.CENTER);
CheckboxItem.setDefaultProperties(checkboxItem);
MultiComboBoxItem multiComboBoxItem = new MultiComboBoxItem();
multiComboBoxItem.setHintStyle("hint");
multiComboBoxItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
multiComboBoxItem.setBrowserSpellCheck(false);
+ multiComboBoxItem.setIconHeight(ITEM_ICON_SIZE);
+ multiComboBoxItem.setIconWidth(ITEM_ICON_SIZE);
+ multiComboBoxItem.setIconVAlign(VerticalAlignment.CENTER);
MultiComboBoxItem.setDefaultProperties(multiComboBoxItem);
SpinnerItem spinnerItem = new SpinnerItem();
@@ -283,11 +307,17 @@ public class ItemFactory {
spinnerItem.setWidth(60);
spinnerItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
spinnerItem.setBrowserSpellCheck(false);
+ spinnerItem.setIconHeight(ITEM_ICON_SIZE);
+ spinnerItem.setIconWidth(ITEM_ICON_SIZE);
+ spinnerItem.setIconVAlign(VerticalAlignment.CENTER);
SpinnerItem.setDefaultProperties(spinnerItem);
PasswordItem passwordItem = new PasswordItem();
passwordItem.setHintStyle("hint");
passwordItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
+ passwordItem.setIconHeight(ITEM_ICON_SIZE);
+ passwordItem.setIconWidth(ITEM_ICON_SIZE);
+ passwordItem.setIconVAlign(VerticalAlignment.CENTER);
TextItem.setDefaultProperties(passwordItem);
StaticTextItem staticTextItem = new StaticTextItem();
@@ -295,12 +325,18 @@ public class ItemFactory {
staticTextItem.setHintStyle("hint");
staticTextItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
staticTextItem.setBrowserSpellCheck(false);
+ staticTextItem.setIconHeight(ITEM_ICON_SIZE);
+ staticTextItem.setIconWidth(ITEM_ICON_SIZE);
+ staticTextItem.setIconVAlign(VerticalAlignment.CENTER);
StaticTextItem.setDefaultProperties(staticTextItem);
IntegerItem integerItem = new IntegerItem();
integerItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
integerItem.setHintStyle("hint");
integerItem.setBrowserSpellCheck(false);
+ integerItem.setIconHeight(ITEM_ICON_SIZE);
+ integerItem.setIconWidth(ITEM_ICON_SIZE);
+ integerItem.setIconVAlign(VerticalAlignment.CENTER);
IntegerItem.setDefaultProperties(integerItem);
ColorPickerItem colorPickerItem = new ColorPickerItem();
@@ -308,12 +344,18 @@ public class ItemFactory {
colorPickerItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
colorPickerItem.setHintStyle("hint");
colorPickerItem.setBrowserSpellCheck(false);
+ colorPickerItem.setIconHeight(ITEM_ICON_SIZE);
+ colorPickerItem.setIconWidth(ITEM_ICON_SIZE);
+ colorPickerItem.setIconVAlign(VerticalAlignment.CENTER);
ColorPickerItem.setDefaultProperties(colorPickerItem);
LinkItem linkItem = new LinkItem();
linkItem.setRequiredMessage(I18N.message(FIELDREQUIRED));
linkItem.setHintStyle("hint");
linkItem.setBrowserSpellCheck(false);
+ linkItem.setIconHeight(ITEM_ICON_SIZE);
+ linkItem.setIconWidth(ITEM_ICON_SIZE);
+ linkItem.setIconVAlign(VerticalAlignment.CENTER);
LinkItem.setDefaultProperties(linkItem);
TextAreaItem textAreaItem = new TextAreaItem();
@@ -321,27 +363,42 @@ public class ItemFactory {
textAreaItem.setHintStyle("hint");
textAreaItem.setBrowserSpellCheck(false);
textAreaItem.setIconVAlign(VerticalAlignment.CENTER);
+ textAreaItem.setIconHeight(ITEM_ICON_SIZE);
+ textAreaItem.setIconWidth(ITEM_ICON_SIZE);
+ textAreaItem.setIconVAlign(VerticalAlignment.CENTER);
TextAreaItem.setDefaultProperties(textAreaItem);
TimeItem timeItem = new TimeItem();
timeItem.setHintStyle("hint");
timeItem.setWidth(60);
timeItem.setBrowserSpellCheck(false);
+ timeItem.setIconHeight(ITEM_ICON_SIZE);
+ timeItem.setIconWidth(ITEM_ICON_SIZE);
+ timeItem.setIconVAlign(VerticalAlignment.CENTER);
TimeItem.setDefaultProperties(timeItem);
FloatItem floatItem = new FloatItem();
floatItem.setHintStyle("hint");
floatItem.setBrowserSpellCheck(false);
+ floatItem.setIconHeight(ITEM_ICON_SIZE);
+ floatItem.setIconWidth(ITEM_ICON_SIZE);
+ floatItem.setIconVAlign(VerticalAlignment.CENTER);
FloatItem.setDefaultProperties(floatItem);
ColorPickerItem colorItemPicker = new ColorPickerItem();
colorItemPicker.setHintStyle("hint");
colorItemPicker.setWidth(115);
colorItemPicker.setBrowserSpellCheck(false);
+ colorItemPicker.setIconHeight(ITEM_ICON_SIZE);
+ colorItemPicker.setIconWidth(ITEM_ICON_SIZE);
+ colorItemPicker.setIconVAlign(VerticalAlignment.CENTER);
ColorPickerItem.setDefaultProperties(colorItemPicker);
RichTextItem richTextItem = new RichTextItem();
richTextItem.setBrowserSpellCheck(false);
+ richTextItem.setIconHeight(ITEM_ICON_SIZE);
+ richTextItem.setIconWidth(ITEM_ICON_SIZE);
+ richTextItem.setIconVAlign(VerticalAlignment.CENTER);
RichTextItem.setDefaultProperties(richTextItem);
}
@@ -361,11 +418,15 @@ public static ColorPickerItem newColorPickerItem(String name, String title, Stri
item.setValue(value);
if (clearOption) {
- PickerIcon clear = new PickerIcon(PickerIcon.CLEAR, (FormItemIconClickEvent event) -> {
+ FormItemIcon clear = new FormItemIcon();
+ clear.setPrompt(I18N.message("clear"));
+ clear.setSrc("[SKIN]/trash.svg");
+ clear.addFormItemClickHandler(click -> {
item.setValue((String) null);
if (changedHandler != null)
changedHandler.onChanged(null);
});
+
item.setIcons(clear);
item.setIconVAlign(VerticalAlignment.CENTER);
}
@@ -1153,14 +1214,15 @@ public static SelectItem newEventsSelector(String name, String title, final Chan
if (handler != null)
select.addChangedHandler(handler);
- PickerIcon clear = new PickerIcon(PickerIcon.CLEAR, click -> {
+ FormItemIcon clear = new FormItemIcon();
+ clear.setPrompt(I18N.message("clear"));
+ clear.setSrc("[SKIN]/trash.svg");
+ clear.addFormItemClickHandler(click -> {
select.clearValue();
select.setValue((String) null);
if (handler != null)
handler.onChanged(null);
});
- clear.setWidth(12);
- clear.setHeight(12);
select.setIcons(clear);
return select;
@@ -1178,14 +1240,15 @@ public static SelectItem newEventSelector(String name, String title, final Chang
if (handler != null)
select.addChangedHandler(handler);
- PickerIcon clear = new PickerIcon(PickerIcon.CLEAR, (FormItemIconClickEvent event) -> {
+ FormItemIcon clear = new FormItemIcon();
+ clear.setPrompt(I18N.message("clear"));
+ clear.setSrc("[SKIN]/trash.svg");
+ clear.addFormItemClickHandler(click -> {
select.clearValue();
select.setValue((String) null);
if (handler != null)
handler.onChanged(null);
});
- clear.setWidth(12);
- clear.setHeight(12);
select.setIcons(clear);
return select;
@@ -1311,9 +1374,7 @@ public static TextItem newCronExpressionItem(String name, String title, String v
FormItemIcon composer = new FormItemIcon();
composer.setPrompt(I18N.message("opencronexpressioncomposer"));
- composer.setSrc("[SKIN]/DynamicForm/date_control.png");
- composer.setWidth(16);
- composer.setHeight(16);
+ composer.setSrc("[SKIN]/calendar-lines-pen.svg");
composer.addFormItemClickHandler(click -> {
new CronExpressionComposer(cron, handler).show();
click.cancel();
@@ -1321,9 +1382,7 @@ public static TextItem newCronExpressionItem(String name, String title, String v
FormItemIcon validate = new FormItemIcon();
validate.setPrompt(I18N.message("validate"));
- validate.setSrc("[SKIN]/actions/approve.png");
- validate.setWidth(16);
- validate.setHeight(16);
+ validate.setSrc("[SKIN]/check.svg");
validate.addFormItemClickHandler(click -> InfoService.Instance.get().getCronDescription(cron.getValueAsString(),
I18N.getLocale(), new AsyncCallback() {
@@ -1341,14 +1400,15 @@ public void onSuccess(String description) {
}
}));
- PickerIcon clear = new PickerIcon(PickerIcon.CLEAR, click -> {
+ FormItemIcon clear = new FormItemIcon();
+ clear.setPrompt(I18N.message("clear"));
+ clear.setSrc("[SKIN]/trash.svg");
+ clear.addFormItemClickHandler(click -> {
cron.setValue((String) null);
cron.clearErrors();
if (handler != null)
handler.onChanged(null);
});
- clear.setWidth(16);
- clear.setHeight(16);
cron.setIcons(composer, validate, clear);
return cron;
@@ -1516,8 +1576,7 @@ public static PasswordItem newPasswordItem(String name, String title, String val
password.setName(originalItemName(name));
if (value != null)
password.setValue(value);
- password.setIconVAlign(VerticalAlignment.CENTER);
-
+
FormItemIcon showPassword = newShowPasswordIcon();
password.setIcons(showPassword);
@@ -1528,9 +1587,7 @@ public static PasswordItem newPasswordItem(String name, String title, String val
private static FormItemIcon newShowPasswordIcon() {
FormItemIcon showPassword = new FormItemIcon();
showPassword.setName("showpassword");
- showPassword.setWidth(16);
- showPassword.setHeight(16);
- showPassword.setSrc("[SKIN]/eye.png");
+ showPassword.setSrc("[SKIN]/eye.svg");
showPassword.setPrompt(I18N.message("showpassword"));
showPassword.addFormItemClickHandler(event -> {
NodeList inputElements = Document.get().getElementsByTagName("input");
@@ -1561,9 +1618,7 @@ public static PasswordItem newPasswordItemPreventAutocomplete(String name, Strin
if (withGeneratorTool) {
FormItemIcon generator = new FormItemIcon();
generator.setName("generator");
- generator.setWidth(16);
- generator.setHeight(16);
- generator.setSrc("[SKIN]/key.png");
+ generator.setSrc("[SKIN]/key.svg");
generator.setPrompt(I18N.message("passwordgenerator"));
generator.addFormItemClickHandler(event -> new PasswordGenerator().show());
password.setIcons(newShowPasswordIcon(), generator);
@@ -1590,19 +1645,19 @@ public static StaticTextItem newSafePasswordItem(String name, String title, Stri
FormItem hiddenPasswordItem, ChangedHandler changedHandler) {
StaticTextItem item = newStaticTextItem(name, title, value == null || value.isEmpty() ? "" : "*****");
- PickerIcon clear = new PickerIcon(PickerIcon.CLEAR, pick -> {
+ FormItemIcon clear = new FormItemIcon();
+ clear.setPrompt(I18N.message("clear"));
+ clear.setSrc("[SKIN]/trash.svg");
+ clear.addFormItemClickHandler(click -> {
item.setValue((String) null);
hiddenPasswordItem.setValue((String) null);
if (changedHandler != null)
changedHandler.onChanged(null);
});
- clear.setPrompt(I18N.message("clear"));
FormItemIcon edit = new FormItemIcon();
edit.setName("edit");
- edit.setWidth(16);
- edit.setHeight(16);
- edit.setSrc("[SKIN]/edit.png");
+ edit.setSrc("[SKIN]/pen-to-square.svg");
edit.setPrompt(I18N.message("edit"));
edit.addFormItemClickHandler(event -> {
PasswordItem password = newPasswordItem("psw", title,
@@ -1892,11 +1947,11 @@ public static LinkItem newLinkItem(String name, String title, String linkTitle,
final CopyTextFormItemIcon copyTextFormItemIcon = new CopyTextFormItemIcon(
textToCopy != null ? textToCopy : url, textToCopy != null ? "copytext" : "copylink");
- if (Feature.isCommercial())
- linkItem.setIcons(copyTextFormItemIcon, qrFormItemIcon);
- else
+ if (Util.isCommunity())
linkItem.setIcons(copyTextFormItemIcon);
-
+ else
+ linkItem.setIcons(copyTextFormItemIcon, qrFormItemIcon);
+
return linkItem;
}
@@ -1950,8 +2005,6 @@ public static TextAreaItem newTextAreaItemForAutomation(String name, String valu
private static void appendAutomationEditorIcon(FormItem item, ChangedHandler handler, boolean withHtmlEditor) {
FormItemIcon editAutomation = new FormItemIcon();
editAutomation.setName("editautomation");
- editAutomation.setWidth(16);
- editAutomation.setHeight(16);
editAutomation.setSrc("[SKIN]/java.png");
editAutomation.setPrompt(I18N.message("openautomationeditor"));
editAutomation.addFormItemClickHandler(click -> new AutomationItemEditor(item, handler).show());
@@ -1966,9 +2019,7 @@ private static void appendAutomationEditorIcon(FormItem item, ChangedHandler han
private static FormItemIcon prepareEditHtmlIcon(FormItem item, ChangedHandler handler) {
FormItemIcon editHtml = new FormItemIcon();
editHtml.setName(EDITHTML);
- editHtml.setWidth(16);
- editHtml.setHeight(16);
- editHtml.setSrc("[SKIN]/html.png");
+ editHtml.setSrc("[SKIN]/code.svg");
editHtml.setPrompt(I18N.message("openhtmleditor"));
editHtml.addFormItemClickHandler(click -> new HtmlItemEditor(item, handler).show());
return editHtml;
@@ -2664,13 +2715,14 @@ public static SelectItem newSubscriptionTypeSelector() {
selector.setValueMap(opts);
selector.setRequired(false);
- PickerIcon clear = new PickerIcon(PickerIcon.CLEAR, (FormItemIconClickEvent event) -> {
+ FormItemIcon clear = new FormItemIcon();
+ clear.setPrompt(I18N.message("clear"));
+ clear.setSrc("[SKIN]/trash.svg");
+ clear.addFormItemClickHandler(click -> {
selector.clearValue();
selector.setValue((String) null);
selector.fireEvent(new ChangedEvent(selector.getJsObj()));
});
- clear.setWidth(12);
- clear.setHeight(12);
selector.setIcons(clear);
return selector;
@@ -2694,9 +2746,7 @@ public static TextAreaItem newTextAreaItemForNote(String name, String title, Str
if (withSimplifiedHtmlEditor) {
FormItemIcon editHtml = new FormItemIcon();
editHtml.setName(EDITHTML);
- editHtml.setWidth(16);
- editHtml.setHeight(16);
- editHtml.setSrc("[SKIN]/html.png");
+ editHtml.setSrc("[SKIN]/code.svg");
editHtml.setPrompt(I18N.message("openhtmleditor"));
editHtml.addFormItemClickHandler(click -> {
RichTextItem htmlItem = newRichTextItemForNote("html", "html", item.getValueAsString());
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/Util.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/Util.java
index e5f161810..dc11b5af4 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/Util.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/util/Util.java
@@ -181,10 +181,10 @@ public static String qrURL(String content, int size) {
}
public static String qrImg(String content, int size) {
- if (Feature.isCommercial())
- return "";
- else
+ if (isCommunity())
return "";
+ else
+ return "";
}
public static String displayURL(Long docId, Long folderId) {
@@ -454,6 +454,10 @@ public static boolean isCommunity() {
return !Feature.enabled(Feature.ADDITIONAL_FORMATS);
}
+ public static boolean isCommercial() {
+ return Feature.enabled(Feature.ADDITIONAL_FORMATS);
+ }
+
public static boolean isOfficeFileType(String type) {
return officeExts.stream().anyMatch(type::equalsIgnoreCase);
}
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/CopyTextFormItemIcon.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/CopyTextFormItemIcon.java
index cab8e2b49..65db348e4 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/CopyTextFormItemIcon.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/CopyTextFormItemIcon.java
@@ -22,8 +22,6 @@ public CopyTextFormItemIcon(String text, String tooltip) {
setName("copy");
setPrompt(I18N.message(tooltip));
setSrc("[SKIN]/paste.svg");
- setWidth(16);
- setHeight(16);
addFormItemClickHandler(event -> {
if (text != null)
Util.copyText(text);
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/FolderSelector.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/FolderSelector.java
index 1e2f89677..1a77c9ace 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/FolderSelector.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/FolderSelector.java
@@ -9,7 +9,6 @@
import com.logicaldoc.gui.common.client.data.FoldersDS;
import com.logicaldoc.gui.common.client.i18n.I18N;
import com.logicaldoc.gui.frontend.client.document.DocumentsPanel;
-import com.logicaldoc.gui.frontend.client.folder.FolderSearchDialog;
import com.smartgwt.client.widgets.form.fields.FormItemIcon;
import com.smartgwt.client.widgets.form.fields.PickerIcon;
import com.smartgwt.client.widgets.form.fields.TextItem;
@@ -54,32 +53,33 @@ public FolderSelector(String name, List additionalIcons) {
setFolder(Long.parseLong(item.getAttributeAsString("folderId")), item.getAttributeAsString("name"));
});
- PickerIcon search = new PickerIcon(PickerIcon.SEARCH,
- event -> new FolderSearchDialog(FolderSelector.this).show());
+ FormItemIcon search = new FormItemIcon();
search.setPrompt(I18N.message("search"));
+ search.setSrc("[SKIN]/magnifying-glass.svg");
search.setWidth(12);
search.setHeight(12);
PickerIcon pick = new PickerIcon(PickerIcon.COMBO_BOX, event -> menu.showContextMenu());
FormItemIcon open = new FormItemIcon();
- open.setName("open");
+ open.setPrompt(I18N.message("openfolder"));
+ open.setSrc("[SKIN]/folder.svg");
open.setWidth(12);
open.setHeight(12);
- open.setSrc("[SKIN]/folder.png");
- open.setPrompt(I18N.message("openfolder"));
open.addFormItemClickHandler(click -> {
if (getFolderId() != null)
DocumentsPanel.get().openInFolder(getFolderId(), null);
});
- PickerIcon clear = new PickerIcon(PickerIcon.CLEAR, event -> {
- clearValue();
- setFolder(null, null);
- });
+ FormItemIcon clear = new FormItemIcon();
clear.setPrompt(I18N.message("clear"));
+ clear.setSrc("[SKIN]/trash.svg");
clear.setWidth(12);
clear.setHeight(12);
+ clear.addFormItemClickHandler(click -> {
+ clearValue();
+ setFolder(null, null);
+ });
List icons = new ArrayList<>();
icons.add(pick);
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/QRFormItemIcon.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/QRFormItemIcon.java
index 441bf970e..4921ab735 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/QRFormItemIcon.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/QRFormItemIcon.java
@@ -1,7 +1,7 @@
package com.logicaldoc.gui.common.client.widgets;
-import com.logicaldoc.gui.common.client.Feature;
import com.logicaldoc.gui.common.client.i18n.I18N;
+import com.logicaldoc.gui.common.client.util.Util;
import com.smartgwt.client.widgets.form.fields.FormItemIcon;
/**
@@ -20,23 +20,18 @@ public class QRFormItemIcon extends FormItemIcon {
*/
public QRFormItemIcon(String code, String tooltip) {
setName("qrcode");
- if (Feature.isCommercial()) {
+ if (Util.isCommercial()) {
setPrompt(I18N.message(tooltip));
setSrc("[SKIN]/qrcode.svg");
- setWidth(16);
- setHeight(16);
-
addFormItemClickHandler(event -> {
String content = code;
if (content == null)
content = event.getItem().getValue().toString();
- new QRLightbox(content, "qrcode", 150).show();
+ new QRLightbox(content).show();
});
} else {
setSrc("[SKIN]/blank.png");
setText("");
- setWidth(16);
- setHeight(16);
setDisabled(true);
}
}
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/QRLightbox.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/QRLightbox.java
index 985905b4f..0760496b1 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/QRLightbox.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/common/client/widgets/QRLightbox.java
@@ -22,40 +22,43 @@
*
*/
public class QRLightbox extends Window {
- public QRLightbox(String content, String title, int size) {
+ private static final int QR_SIZE = 150;
+
+ public QRLightbox(String content) {
setHeaderControls(HeaderControls.HEADER_LABEL, HeaderControls.CLOSE_BUTTON);
- setTitle(I18N.message(title));
+ setTitle(I18N.message("qrcode"));
setCanDragResize(true);
setIsModal(true);
setShowModalMask(true);
setAutoSize(true);
centerInPage();
-
- String qrUrl1 = Util.qrURL(content, size);
+
+ String qrUrl1 = Util.qrURL(content, QR_SIZE);
if ((content.startsWith("http") || content.startsWith("https")) && content.startsWith(Util.contextPath())
&& !content.startsWith(Session.get().getConfig("server.url"))) {
-
- // We are not accessing from the declared server.url so display the additional QR with server.url
+
+ // We are not accessing from the declared server.url so display the
+ // additional QR with server.url
final StringBuilder content2 = new StringBuilder(Session.get().getConfig("server.url"));
if (!content2.toString().endsWith("/"))
content2.append("/");
content2.append(content.substring(Util.contextPath().length()));
-
- String qrUrl2 = Util.qrURL(content2.toString(), size);
-
+
+ String qrUrl2 = Util.qrURL(content2.toString(), QR_SIZE);
+
ImageLoader.loadImages(new String[] { qrUrl1, qrUrl2 }, imageElements -> {
- StaticTextItem qr1Item = ItemFactory.newStaticTextItem("qr1", title,
- "");
+ StaticTextItem qr1Item = ItemFactory.newStaticTextItem("qr1", "qrcode",
+ "");
qr1Item.setWrap(false);
qr1Item.setWrapTitle(false);
qr1Item.setShowTitle(false);
- StaticTextItem qr2Item = ItemFactory.newStaticTextItem("qr2", title,
- "");
+ StaticTextItem qr2Item = ItemFactory.newStaticTextItem("qr2", "qrcode",
+ "");
qr2Item.setWrap(false);
qr2Item.setWrapTitle(false);
qr2Item.setShowTitle(false);
@@ -68,11 +71,12 @@ public QRLightbox(String content, String title, int size) {
addItem(form);
});
} else {
- // We are accessing from the declared server.url so just display the QR
+ // We are accessing from the declared server.url so just display the
+ // QR
ImageLoader.loadImages(new String[] { qrUrl1 }, imageElements -> {
Img img = new Img(qrUrl1);
- img.setImageWidth(size);
- img.setImageHeight(size);
+ img.setImageWidth(QR_SIZE);
+ img.setImageHeight(QR_SIZE);
img.setImageType(ImageStyle.NORMAL);
addItem(img);
});
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/DocumentStandardPropertiesPanel.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/DocumentStandardPropertiesPanel.java
index 06a44bda7..7f5e24414 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/DocumentStandardPropertiesPanel.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/DocumentStandardPropertiesPanel.java
@@ -21,7 +21,6 @@
import com.logicaldoc.gui.common.client.widgets.preview.PreviewTile;
import com.logicaldoc.gui.frontend.client.services.DocumentService;
import com.smartgwt.client.data.Record;
-import com.smartgwt.client.types.PickerIconName;
import com.smartgwt.client.types.TitleOrientation;
import com.smartgwt.client.util.SC;
import com.smartgwt.client.widgets.form.DynamicForm;
@@ -31,12 +30,10 @@
import com.smartgwt.client.widgets.form.fields.FormItemIcon;
import com.smartgwt.client.widgets.form.fields.LinkItem;
import com.smartgwt.client.widgets.form.fields.MultiComboBoxItem;
-import com.smartgwt.client.widgets.form.fields.PickerIcon;
import com.smartgwt.client.widgets.form.fields.SelectItem;
import com.smartgwt.client.widgets.form.fields.StaticTextItem;
import com.smartgwt.client.widgets.form.fields.TextItem;
import com.smartgwt.client.widgets.form.fields.events.ChangedHandler;
-import com.smartgwt.client.widgets.form.fields.events.FormItemIconClickEvent;
import com.smartgwt.client.widgets.layout.HLayout;
import com.smartgwt.client.widgets.layout.Layout;
import com.smartgwt.client.widgets.layout.VLayout;
@@ -152,8 +149,10 @@ private StaticTextItem preparePermaLink() {
StaticTextItem permaLink = ItemFactory.newStaticTextItem("permalink", perma);
- if (Feature.isCommercial()) {
- FormItemIcon qrCode = new QRFormItemIcon();
+ if (Util.isCommercial()) {
+ FormItemIcon qrCode = new FormItemIcon();
+ qrCode.setPrompt(I18N.message("qrcode"));
+ qrCode.setSrc("[SKIN]/qrcode.svg");
qrCode.addFormItemClickHandler(click -> new PermaLinkDisplay(document.getId()).show());
permaLink.setIcons(qrCode);
}
@@ -168,7 +167,7 @@ private StaticTextItem prepareIdItem() {
id.setValue(Util.padLeft(Long.toString(document.getId()) + " (" + document.getCustomId() + ")", 35));
}
- if (Feature.isCommercial()) {
+ if (Util.isCommercial()) {
StringBuilder sb = new StringBuilder("id: ");
sb.append(document.getId());
sb.append("_CR_filename: ");
@@ -243,11 +242,13 @@ private LinkItem prepareFolderItem() {
private StaticTextItem preparePagesItem() {
StaticTextItem pages = ItemFactory.newStaticTextItem("pages", Util.formatInt(document.getPages()));
pages.setIconHSpace(2);
- pages.setIconWidth(16);
- pages.setIconHeight(16);
pages.setWidth("1%");
- PickerIcon countPages = new PickerIcon(PickerIconName.REFRESH, (final FormItemIconClickEvent event) -> {
- event.getItem().setValue(I18N.message("computing") + "...");
+
+ FormItemIcon countPages = new FormItemIcon();
+ countPages.setSrc("[SKIN]/arrows-rotate.svg");
+ countPages.setPrompt(I18N.message("countpages"));
+ countPages.addFormItemClickHandler(click -> {
+ click.getItem().setValue(I18N.message("computing") + "...");
DocumentService.Instance.get().updatePages(document.getId(), new AsyncCallback<>() {
@Override
@@ -264,7 +265,7 @@ public void onSuccess(Integer docPages) {
}
});
});
- countPages.setPrompt(I18N.message("countpages"));
+
if (document.getId() != 0)
pages.setIcons(countPages);
return pages;
@@ -315,9 +316,7 @@ private void addTags(List items) {
FormItemIcon editTags = new FormItemIcon();
editTags.setPrompt(I18N.message("edittags"));
- editTags.setSrc("[SKIN]/actions/edit.png");
- editTags.setWidth(16);
- editTags.setHeight(16);
+ editTags.setSrc("[SKIN]/pen-to-square.svg");
editTags.addFormItemClickHandler(event -> {
tagsString.setVisible(false);
tagItem.setVisible(true);
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/DocumentToolbar.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/DocumentToolbar.java
index 11bff5977..30a5e4619 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/DocumentToolbar.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/DocumentToolbar.java
@@ -473,7 +473,7 @@ private void addOffice() {
if (Feature.visible(Feature.OFFICE)) {
addButton(office);
office.setTooltip(I18N.message("editwithoffice"));
- office.setTitle("");
+ office.setTitle("");
if (!Feature.enabled(Feature.OFFICE))
setFeatureDisabled(office);
@@ -488,7 +488,7 @@ private void addOnlyOffice() {
&& Session.get().getConfigAsBoolean("converter.OnlyOfficeConverter.enabled")) {
addButton(onlyoffice);
onlyoffice.setTooltip(I18N.message("editwithonlyoffice"));
- onlyoffice.setTitle("");
+ onlyoffice.setTitle("");
if (!Feature.enabled(Feature.OFFICE))
setFeatureDisabled(onlyoffice);
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/PermaLinkDisplay.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/PermaLinkDisplay.java
index d857ba122..2291c63ac 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/PermaLinkDisplay.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/document/PermaLinkDisplay.java
@@ -10,7 +10,6 @@
import com.smartgwt.client.types.TitleOrientation;
import com.smartgwt.client.widgets.Window;
import com.smartgwt.client.widgets.form.DynamicForm;
-import com.smartgwt.client.widgets.form.fields.ButtonItem;
import com.smartgwt.client.widgets.form.fields.StaticTextItem;
/**
@@ -44,22 +43,23 @@ public PermaLinkDisplay(long docId) {
ImageLoader.loadImages(new String[] { Util.qrURL(downloadUrl, QR_SIZE), Util.qrURL(downloadUrl2, QR_SIZE),
Util.qrURL(displayUrl, QR_SIZE), Util.qrURL(displayUrl2, QR_SIZE) }, imageElements -> {
- DynamicForm form = new DynamicForm();
- form.setMargin(4);
- form.setTitleOrientation(TitleOrientation.LEFT);
-
StaticTextItem downloadUrlItem = prepareBarcodeAndLink("download1", "download", downloadUrl);
+ downloadUrlItem.setShowTitle(true);
StaticTextItem downloadUrlItem2 = prepareBarcodeAndLink("download2", "download", downloadUrl2);
+ downloadUrlItem2.setShowTitle(false);
downloadUrlItem2.setVisible(!downloadUrl.equals(downloadUrl2));
- StaticTextItem displayUrlItem = prepareBarcodeAndLink("displayUrl", "details", displayUrl);
+ StaticTextItem displayUrlItem = prepareBarcodeAndLink("displayUrl1", "details", displayUrl);
+ displayUrlItem.setShowTitle(true);
StaticTextItem displayUrlItem2 = prepareBarcodeAndLink("displayUrl2", "details", displayUrl2);
- displayUrlItem2.setVisible(!downloadUrl.equals(downloadUrl2));
+ displayUrlItem2.setShowTitle(false);
+ displayUrlItem2.setVisible(!displayUrl.equals(displayUrl2));
- ButtonItem close = new ButtonItem("close", I18N.message("close"));
- close.addClickHandler(event -> PermaLinkDisplay.this.destroy());
-
- form.setItems(downloadUrlItem, downloadUrlItem2, displayUrlItem, displayUrlItem2, close);
+ DynamicForm form = new DynamicForm();
+ form.setNumCols(1);
+ form.setMargin(2);
+ form.setTitleOrientation(TitleOrientation.TOP);
+ form.setItems(downloadUrlItem, downloadUrlItem2, displayUrlItem, displayUrlItem2);
addItem(form);
});
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/folder/FolderStandardPropertiesPanel.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/folder/FolderStandardPropertiesPanel.java
index cc5f5d165..03776d2ac 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/folder/FolderStandardPropertiesPanel.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/folder/FolderStandardPropertiesPanel.java
@@ -112,22 +112,16 @@ private void refresh() {
final StaticTextItem documents = ItemFactory.newStaticTextItem("documents",
folder.getDocumentCount() > 0 ? Util.formatLong(folder.getDocumentCount()) : "-");
documents.setIconHSpace(2);
- documents.setIconWidth(16);
- documents.setIconHeight(16);
documents.setWidth("1%");
final StaticTextItem subfolders = ItemFactory.newStaticTextItem("folders",
folder.getSubfolderCount() > 0 ? Util.formatLong(folder.getSubfolderCount()) : "-");
subfolders.setIconHSpace(2);
- subfolders.setIconWidth(16);
- subfolders.setIconHeight(16);
subfolders.setWidth("1%");
final StaticTextItem size = ItemFactory.newStaticTextItem("size",
folder.getSize() > 0 ? Util.formatSize(folder.getSize()) : "-");
size.setIconHSpace(2);
- size.setIconWidth(16);
- size.setIconHeight(16);
size.setWidth("1%");
addComputeStatsIcons(documents, subfolders, size);
@@ -162,7 +156,7 @@ private StaticTextItem prepareIdItem() {
sb.append("_CR_path: ");
sb.append(folder.getPathExtended());
- if (Feature.isCommercial())
+ if (Util.isCommercial())
id.setIcons(new QRFormItemIcon(sb.toString()));
if (folder.getFoldRef() != null)
@@ -197,8 +191,6 @@ private void addComputeStatsIcons(StaticTextItem documents, StaticTextItem subfo
FormItemIcon computeStats = new FormItemIcon();
computeStats.setPrompt(I18N.message("calculatestats"));
computeStats.setSrc("[SKIN]/arrows-rotate.svg");
- computeStats.setWidth(16);
- computeStats.setHeight(16);
computeStats.addFormItemClickHandler(click -> {
click.getItem().setValue(I18N.message("computing") + "...");
FolderService.Instance.get().computeStats(folder.getId(), new AsyncCallback<>() {
@@ -241,9 +233,6 @@ private FormItemIcon prepareEnforceStore() {
FormItemIcon enforceStore = new FormItemIcon();
enforceStore.setPrompt(I18N.message("enforcefilesintofolderstorage"));
enforceStore.setSrc("[SKIN]/boxes-stacked.svg");
- enforceStore.setWidth(16);
- enforceStore.setHeight(16);
-
enforceStore.addFormItemClickHandler(event -> {
LD.ask(I18N.message("enforcementofstorage"),
I18N.message("enforcefilesintofolderstorage") + ".\n" + I18N.message("doyouwanttoproceed"), yes -> {
@@ -275,9 +264,6 @@ private FormItemIcon prepareApplyStoreToSubfoldersItem() {
FormItemIcon applyStoreToSubfolders = new FormItemIcon();
applyStoreToSubfolders.setPrompt(I18N.message("applytosubfolders"));
applyStoreToSubfolders.setSrc("[SKIN]/clone.svg");
-
- applyStoreToSubfolders.setWidth(16);
- applyStoreToSubfolders.setHeight(16);
applyStoreToSubfolders.addFormItemClickHandler(applyStoreToSubfoldersClick -> {
LD.contactingServer();
FolderService.Instance.get().applyStore(folder.getId(), new AsyncCallback<>() {
@@ -343,13 +329,11 @@ private void fillRightForm() {
final TextItem newTagItem = prepareNewTagItem(ds);
final StaticTextItem tagsString = ItemFactory.newStaticTextItem("tags", "tag",
- Util.getTagsHTML(folder.getTags()));
+ Util.getTagsHTML(folder.getTags()));
tagsString.setEndRow(true);
FormItemIcon editTags = new FormItemIcon();
editTags.setPrompt(I18N.message("edittags"));
- editTags.setSrc("[SKIN]/actions/edit.png");
- editTags.setWidth(16);
- editTags.setHeight(16);
+ editTags.setSrc("[SKIN]/pen-to-square.svg");
editTags.addFormItemClickHandler(editTagClick -> {
tagsString.setVisible(false);
tagItem.setVisible(true);
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/search/FulltextForm.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/search/FulltextForm.java
index 99944fb6a..417859db7 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/search/FulltextForm.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/search/FulltextForm.java
@@ -23,10 +23,10 @@
import com.smartgwt.client.widgets.form.DynamicForm;
import com.smartgwt.client.widgets.form.ValuesManager;
import com.smartgwt.client.widgets.form.fields.CheckboxItem;
+import com.smartgwt.client.widgets.form.fields.FormItemIcon;
import com.smartgwt.client.widgets.form.fields.IntegerItem;
import com.smartgwt.client.widgets.form.fields.MiniDateRangeItem;
import com.smartgwt.client.widgets.form.fields.MultiComboBoxItem;
-import com.smartgwt.client.widgets.form.fields.PickerIcon;
import com.smartgwt.client.widgets.form.fields.SelectItem;
import com.smartgwt.client.widgets.form.fields.TextItem;
import com.smartgwt.client.widgets.layout.VLayout;
@@ -82,17 +82,22 @@ private void initGUI() {
form1.setTitleOrientation(TitleOrientation.TOP);
form1.setNumCols(3);
- PickerIcon searchPicker = new PickerIcon(PickerIcon.SEARCH, event -> search());
- PickerIcon clear = new PickerIcon(PickerIcon.CLEAR, event -> {
- vm.clearValues();
- prepareFields(null);
- });
-
+ FormItemIcon search = new FormItemIcon();
+ search.setPrompt(I18N.message("search"));
+ search.setSrc("[SKIN]/magnifying-glass.svg");;
+ search.addFormItemClickHandler(click -> search());
+
+ FormItemIcon clear = new FormItemIcon();
+ clear.setPrompt(I18N.message("clear"));
+ clear.setSrc("[SKIN]/trash.svg");
+ clear.addFormItemClickHandler(click -> {vm.clearValues();
+ prepareFields(null);});
+
expression = ItemFactory.newTextItem(EXPRESSION_STR, I18N.message("search") + "...");
expression.setWidth("*");
expression.setColSpan(3);
expression.setRequired(true);
- expression.setIcons(searchPicker, clear);
+ expression.setIcons(search, clear);
expression.addKeyPressHandler(event -> {
if (event.getKeyName() == null)
return;
@@ -115,9 +120,9 @@ private void initGUI() {
SelectItem template = ItemFactory.newTemplateSelector(true, null);
template.setMultiple(false);
template.setColSpan(3);
- template.addChangedHandler(event -> {
- if (event.getValue() != null && !"".equals(event.getValue()))
- prepareFields(Long.parseLong((String) event.getValue()));
+ template.addChangedHandler(changed -> {
+ if (changed.getValue() != null && !"".equals(changed.getValue()))
+ prepareFields(Long.parseLong((String) changed.getValue()));
else
prepareFields(null);
});
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/search/TagsForm.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/search/TagsForm.java
index 38d9e5b18..e8d572cbf 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/search/TagsForm.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/search/TagsForm.java
@@ -19,7 +19,7 @@
import com.smartgwt.client.types.SelectionStyle;
import com.smartgwt.client.widgets.form.DynamicForm;
import com.smartgwt.client.widgets.form.fields.FormItem;
-import com.smartgwt.client.widgets.form.fields.PickerIcon;
+import com.smartgwt.client.widgets.form.fields.FormItemIcon;
import com.smartgwt.client.widgets.form.fields.StaticTextItem;
import com.smartgwt.client.widgets.form.fields.TextItem;
import com.smartgwt.client.widgets.grid.ListGrid;
@@ -91,7 +91,10 @@ public TagsForm(final boolean admin, final boolean searchInHits) {
otherCharForm = new DynamicForm();
otherCharForm.setWidth(1);
- PickerIcon searchPicker = new PickerIcon(PickerIcon.SEARCH, event -> {
+ FormItemIcon search = new FormItemIcon();
+ search.setPrompt(I18N.message("clear"));
+ search.setSrc("[SKIN]/magnifying-glass.svg");
+ search.addFormItemClickHandler(click -> {
if (!otherCharForm.validate())
return;
onLetterSelect(otherCharForm.getValueAsString("otherchar"));
@@ -100,7 +103,7 @@ public TagsForm(final boolean admin, final boolean searchInHits) {
TextItem otherChar = ItemFactory.newTextItem("otherchar", null);
otherChar.setRequired(true);
otherChar.setWrapTitle(false);
- otherChar.setIcons(searchPicker);
+ otherChar.setIcons(search);
otherChar.setLength(1);
otherChar.setWidth(50);
@@ -165,21 +168,20 @@ private void showContextMenu(boolean admin) {
return;
ListGridRecord selection = tags.getSelectedRecord();
- TagService.Instance.get().rename(selection.getAttribute("word"), value,
- new AsyncCallback<>() {
- @Override
- public void onFailure(Throwable caught) {
- GuiLog.serverError(caught);
- }
-
- @Override
- public void onSuccess(Void arg) {
- GuiLog.info(I18N.message("procinexecution"), I18N.message("taginexecution"));
- ListGridRecord selection = tags.getSelectedRecord();
- selection.setAttribute("word", value);
- onLetterSelect(value.substring(0, 1));
- }
- });
+ TagService.Instance.get().rename(selection.getAttribute("word"), value, new AsyncCallback<>() {
+ @Override
+ public void onFailure(Throwable caught) {
+ GuiLog.serverError(caught);
+ }
+
+ @Override
+ public void onSuccess(Void arg) {
+ GuiLog.info(I18N.message("procinexecution"), I18N.message("taginexecution"));
+ ListGridRecord selection = tags.getSelectedRecord();
+ selection.setAttribute("word", value);
+ onLetterSelect(value.substring(0, 1));
+ }
+ });
}));
contextMenu.addItem(rename);
diff --git a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/settings/searchindex/SearchIndexPanel.java b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/settings/searchindex/SearchIndexPanel.java
index 485e07db6..038ce5225 100644
--- a/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/settings/searchindex/SearchIndexPanel.java
+++ b/logicaldoc-gui/src/main/java/com/logicaldoc/gui/frontend/client/settings/searchindex/SearchIndexPanel.java
@@ -36,7 +36,6 @@
import com.logicaldoc.gui.frontend.client.services.SearchEngineService;
import com.smartgwt.client.types.Alignment;
import com.smartgwt.client.types.ListGridFieldType;
-import com.smartgwt.client.types.PickerIconName;
import com.smartgwt.client.types.SelectionStyle;
import com.smartgwt.client.types.TitleOrientation;
import com.smartgwt.client.util.SC;
@@ -45,7 +44,7 @@
import com.smartgwt.client.widgets.events.ClickEvent;
import com.smartgwt.client.widgets.form.DynamicForm;
import com.smartgwt.client.widgets.form.ValuesManager;
-import com.smartgwt.client.widgets.form.fields.PickerIcon;
+import com.smartgwt.client.widgets.form.fields.FormItemIcon;
import com.smartgwt.client.widgets.form.fields.RadioGroupItem;
import com.smartgwt.client.widgets.form.fields.SelectItem;
import com.smartgwt.client.widgets.form.fields.SpinnerItem;
@@ -399,8 +398,11 @@ private void fillSearchEngineTab() {
searchEngineForm.setColWidths(1, "*");
searchEngineForm.setValuesManager(vm);
- PickerIcon computeStat = new PickerIcon(PickerIconName.REFRESH, iconClick -> {
- iconClick.getItem().setValue(I18N.message("computing") + "...");
+ FormItemIcon computeStats = new FormItemIcon();
+ computeStats.setPrompt(I18N.message("calculatestats"));
+ computeStats.setSrc("[SKIN]/arrows-rotate.svg");
+ computeStats.addFormItemClickHandler(click -> {
+ click.getItem().setValue(I18N.message("computing") + "...");
SearchEngineService.Instance.get().countEntries(new AsyncCallback() {
@Override
@@ -410,20 +412,15 @@ public void onFailure(Throwable caught) {
@Override
public void onSuccess(Long count) {
- iconClick.getItem().setValue(Util.formatLong(count));
+ click.getItem().setValue(Util.formatLong(count));
}
});
});
- computeStat.setPrompt(I18N.message("calculatestats"));
- computeStat.setWidth(16);
-
// Entries count
StaticTextItem entries = ItemFactory.newStaticTextItem("entries", "entriescount", "-");
entries.setIconHSpace(2);
- entries.setIconWidth(16);
- entries.setIconHeight(16);
- entries.setIcons(computeStat);
+ entries.setIcons(computeStats);
entries.setWidth("1%");
// Locked
diff --git a/logicaldoc-gui/src/main/resources/com/logicaldoc/gui/common/Common.gwt.xml b/logicaldoc-gui/src/main/resources/com/logicaldoc/gui/common/Common.gwt.xml
index 4f7e83d04..3d34e1a63 100644
--- a/logicaldoc-gui/src/main/resources/com/logicaldoc/gui/common/Common.gwt.xml
+++ b/logicaldoc-gui/src/main/resources/com/logicaldoc/gui/common/Common.gwt.xml
@@ -1,19 +1,19 @@
-
-
+
+
+
-
\ No newline at end of file
diff --git a/logicaldoc-gui/war/body.jsp b/logicaldoc-gui/war/body.jsp
index d56fb19ba..2a91468e5 100644
--- a/logicaldoc-gui/war/body.jsp
+++ b/logicaldoc-gui/war/body.jsp
@@ -23,7 +23,7 @@
-
+
diff --git a/logicaldoc-gui/war/skin/images/eye.svg b/logicaldoc-gui/war/skin/images/eye.svg
new file mode 100644
index 000000000..932254029
--- /dev/null
+++ b/logicaldoc-gui/war/skin/images/eye.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/logicaldoc-gui/war/skin/images/folder.svg b/logicaldoc-gui/war/skin/images/folder.svg
new file mode 100644
index 000000000..c22031d74
--- /dev/null
+++ b/logicaldoc-gui/war/skin/images/folder.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/logicaldoc-gui/war/skin/images/java.svg b/logicaldoc-gui/war/skin/images/java.svg
new file mode 100644
index 000000000..66a283422
--- /dev/null
+++ b/logicaldoc-gui/war/skin/images/java.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/logicaldoc-gui/war/skin/images/magnifying-glass.svg b/logicaldoc-gui/war/skin/images/magnifying-glass.svg
new file mode 100644
index 000000000..957dc21f1
--- /dev/null
+++ b/logicaldoc-gui/war/skin/images/magnifying-glass.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/logicaldoc-gui/war/skin/images/pen-to-square.svg b/logicaldoc-gui/war/skin/images/pen-to-square.svg
new file mode 100644
index 000000000..0832ffa88
--- /dev/null
+++ b/logicaldoc-gui/war/skin/images/pen-to-square.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/logicaldoc-gui/war/skin/images/trash.svg b/logicaldoc-gui/war/skin/images/trash.svg
new file mode 100644
index 000000000..655a1fb54
--- /dev/null
+++ b/logicaldoc-gui/war/skin/images/trash.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/logicaldoc-webapp/src/main/java/com/logicaldoc/web/websockets/WebsocketTool.java b/logicaldoc-webapp/src/main/java/com/logicaldoc/web/websockets/WebsocketTool.java
index a4e1af5ec..503f79b06 100644
--- a/logicaldoc-webapp/src/main/java/com/logicaldoc/web/websockets/WebsocketTool.java
+++ b/logicaldoc-webapp/src/main/java/com/logicaldoc/web/websockets/WebsocketTool.java
@@ -35,6 +35,7 @@ public class WebsocketTool {
public void showMessage(Session session, String message, String level) {
WebsocketMessage command = new WebsocketMessage(session.getSid(), "command");
command.setCommand("message");
+ command.setTenantId(session.getTenantId());
command.setUserId(session.getUserId());
command.setUsername(session.getUsername());
command.setPayload(message);
@@ -56,6 +57,7 @@ public void showMessage(Session session, String message, String level) {
public void openUrl(Session session, String url, String target) {
WebsocketMessage command = new WebsocketMessage(session.getSid(), "command");
command.setCommand("openurl");
+ command.setTenantId(session.getTenantId());
command.setUserId(session.getUserId());
command.setUsername(session.getUsername());
command.setPayload(url);
diff --git a/pom.xml b/pom.xml
index 7da28ffbc..4be9ed9c6 100644
--- a/pom.xml
+++ b/pom.xml
@@ -4,7 +4,7 @@
com.logicaldoc
logicaldoc-parent-pom
- 109
+ 110
com.logicaldoc
logicaldoc