Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
A
abook_check
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
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abook_android
abook_check
Commits
bb6c99f5
Commit
bb6c99f5
authored
Jun 06, 2022
by
onuma
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
#47940 前回の入力内容をデフォルトに設定
parent
bce458e5
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
158 additions
and
1 deletions
+158
-1
ABVJE_BL/src/jp/agentec/abook/abv/bl/common/ABVEnvironment.java
+4
-0
ABVJE_BL/src/jp/agentec/abook/abv/bl/common/constant/ABookKeys.java
+2
-0
ABVJE_BL/src/jp/agentec/adf/util/FileUtil.java
+26
-0
ABVJE_UI_Android/src/jp/agentec/abook/abv/ui/common/activity/ABVContentViewActivity.java
+126
-1
No files found.
ABVJE_BL/src/jp/agentec/abook/abv/bl/common/ABVEnvironment.java
View file @
bb6c99f5
...
...
@@ -155,6 +155,10 @@ public class ABVEnvironment {
public
static
final
String
OperationTaskKeyRoutineTaskReportDirFormat
=
OperationTaskKeyDirFormat
+
"/%d/%s/%s"
;
// #32926 作業報告画面改善 end
public
static
final
String
ContinuousTaskReportJsonDirFormat
=
ContentCacheDirectoryFormat
+
"/processList/phaseList/phase_%d"
;
// アルコールチェッカー(userDataKey)を保存する場所
public
static
final
String
userDataDir
=
"/userData/"
;
// 保存するファイル名
public
static
final
String
userDataKeyFile
=
"userDataKey"
;
/**
* コンテンツのファイルを暗号化するときに、暗号化するサイズをバイト単位で指定します。
...
...
ABVJE_BL/src/jp/agentec/abook/abv/bl/common/constant/ABookKeys.java
View file @
bb6c99f5
...
...
@@ -74,6 +74,8 @@ public class ABookKeys {
public
static
final
String
CMD_PAGE_NUM
=
"pageNum"
;
public
static
final
String
CMD_GET_GROUP_TREE_INFO
=
"getGroupTreeInfo"
;
public
static
final
String
CMD_CLOSE_TASK_LIST
=
"closeTaskList"
;
public
static
final
String
CMD_LOAD_USER_DATA
=
"loadUserData"
;
public
static
final
String
CMD_SAVE_USER_DATA
=
"saveUserData"
;
public
static
final
String
GPS_TYPE
=
"gpsType"
;
public
static
final
String
STATUS_CODE
=
"statusCode"
;
...
...
ABVJE_BL/src/jp/agentec/adf/util/FileUtil.java
View file @
bb6c99f5
...
...
@@ -1065,4 +1065,30 @@ public class FileUtil {
fileOutputStream
.
close
();
inputStream
.
close
();
}
/**
* ディレクトリ配下のファイルとディレクトリの一覧を作成して返します。
* @param path ディレクトリ
* @return ファイルとディレクトリの一覧
*/
public
static
File
[]
listFiles
(
String
path
)
{
File
dir
=
new
File
(
path
);
File
[]
list
=
dir
.
listFiles
();
return
list
;
}
/**
* 指定した絶対パスの一番下のフォルダ名を返します
* @param dir ディレクトリ
* @return 一番下のディレクトリ名
*/
public
static
String
getLastChildDirectoryName
(
File
dir
)
{
try
{
String
lastDir
=
dir
.
getPath
().
substring
(
dir
.
getPath
().
lastIndexOf
(
"/"
)
+
1
);
return
lastDir
;
}
catch
(
IndexOutOfBoundsException
e
)
{
}
return
null
;
}
}
ABVJE_UI_Android/src/jp/agentec/abook/abv/ui/common/activity/ABVContentViewActivity.java
View file @
bb6c99f5
...
...
@@ -25,9 +25,15 @@ import android.widget.Toast;
import
org.json.adf.JSONObject
;
import
java.io.BufferedWriter
;
import
java.io.File
;
import
java.io.FileInputStream
;
import
java.io.FileNotFoundException
;
import
java.io.FileOutputStream
;
import
java.io.IOException
;
import
java.io.InputStreamReader
;
import
java.io.OutputStreamWriter
;
import
java.nio.charset.StandardCharsets
;
import
java.util.ArrayList
;
import
java.util.HashMap
;
import
java.util.Iterator
;
...
...
@@ -916,12 +922,18 @@ public abstract class ABVContentViewActivity extends ABVAuthenticatedActivity {
// showHelpViewDialog(helpViewType);
// }
/**
* WebView発生を受け取るメソッド
* @param uri 情報がkey, valueの形式で格納されている
* @param operationTaskDto HotSpotの情報などが入っている。報告タイプによっては、使わないケースもある
*/
public
void
commonShouldOverrideUrlLoading
(
Uri
uri
,
OperationTaskDto
operationTaskDto
)
{
Logger
.
d
(
TAG
,
"Uri : %s"
,
uri
);
//parent method
Map
<
String
,
String
>
abookCheckParam
=
new
HashMap
<
String
,
String
>();
for
(
String
key
:
uri
.
getQueryParameterNames
())
{
abookCheckParam
.
put
(
key
,
uri
.
getQueryParameter
(
key
));
Logger
.
d
(
TAG
,
"key = %s, value = %s"
,
key
,
uri
.
getQueryParameter
(
key
));
}
mCmd
=
abookCheckParam
.
get
(
ABookKeys
.
CMD
);
if
(
abookCheckParam
.
containsKey
(
ABookKeys
.
TASK_KEY
))
{
...
...
@@ -1190,9 +1202,122 @@ public abstract class ABVContentViewActivity extends ABVAuthenticatedActivity {
putUserPref
(
AppDefType
.
UserPrefKey
.
SYNC_TARGET_OPERATION_ID
,
mOperationId
);
finishActivity
();
// 開いてる画面を閉じる
}
}
else
if
(
mCmd
.
equals
(
ABookKeys
.
CMD_LOAD_USER_DATA
))
{
// 前回の入力内容を読み込む
loadUserDataKey
(
abookCheckParam
.
get
(
ABookKeys
.
TASK_KEY
));
}
else
if
(
mCmd
.
equals
(
ABookKeys
.
CMD_SAVE_USER_DATA
))
{
// 入力内容を保存する
saveUserDataKey
(
abookCheckParam
.
get
(
ABookKeys
.
TASK_KEY
));
}
}
/**
* アルコールチェッカー、userDataのルートディレクトリを返す
* 通常 cache/userData/
* @return ルートディレクトリ
*/
private
String
getUserDataDirRoot
()
{
Logger
.
d
(
TAG
,
"userDataDirRoot = %s"
,
ABVEnvironment
.
getInstance
().
cacheDirectory
+
ABVEnvironment
.
getInstance
().
userDataDir
);
return
ABVEnvironment
.
getInstance
().
cacheDirectory
+
ABVEnvironment
.
getInstance
().
userDataDir
;
}
/**
* JSから送られてきたキーデータを保存する
* @param userDataKey 保存するユーザーキー
*/
private
void
saveUserDataKey
(
String
userDataKey
)
{
if
(
StringUtil
.
isNullOrEmpty
(
userDataKey
))
{
// 読み込むためのキーがない
afterABookCheckApi
(
ABookKeys
.
CMD_SAVE_USER_DATA
,
userDataKey
,
1
,
""
,
""
);
return
;
}
// フォルダ作成(すでに存在するなら作成はされない)
String
userDataFolderRoot
=
getUserDataDirRoot
();
FileUtil
.
createNewDirectory
(
userDataFolderRoot
+
ABVDataCache
.
getInstance
().
getMemberInfo
().
loginId
);
File
[]
userDirs
=
FileUtil
.
listFiles
(
userDataFolderRoot
);
for
(
File
dir
:
userDirs
)
{
try
{
Logger
.
d
(
TAG
,
"getAbsolutePath = %s"
,
dir
.
getAbsolutePath
());
// 一番下のフォルダ名 = ユーザーID
String
userId
=
FileUtil
.
getLastChildDirectoryName
(
dir
);
//Logger.d(TAG,"userId = %s", userId);
if
(!
ABVDataCache
.
getInstance
().
getMemberInfo
().
loginId
.
equals
(
userId
))
{
// ログインしているユーザー以外のものは削除
FileUtil
.
delete
(
dir
);
}
BufferedWriter
bw
=
null
;
if
(
userDataKey
!=
null
)
{
try
{
FileOutputStream
fo
=
new
FileOutputStream
(
userDataFolderRoot
+
"/"
+
userId
+
"/"
+
ABVEnvironment
.
getInstance
().
userDataKeyFile
);
OutputStreamWriter
osw
=
new
OutputStreamWriter
(
fo
,
StandardCharsets
.
UTF_8
);
bw
=
new
BufferedWriter
(
osw
);
bw
.
write
(
userDataKey
);
bw
.
close
();
}
catch
(
IOException
e
)
{
System
.
out
.
println
(
"bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb"
);
}
finally
{
try
{
bw
.
close
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
}
afterABookCheckApi
(
ABookKeys
.
CMD_SAVE_USER_DATA
,
userDataKey
,
0
,
""
,
""
);
break
;
}
}
catch
(
IndexOutOfBoundsException
iobex
)
{
System
.
out
.
println
(
"aaaaaaaaaaaaaaaaa"
);
}
}
}
/**
* キーデータファイルを読み込んで、JSにわたす
*/
private
void
loadUserDataKey
(
String
userDataKey
)
{
if
(
StringUtil
.
isNullOrEmpty
(
userDataKey
))
{
// 読み込むためのキーがない
afterABookCheckApi
(
ABookKeys
.
CMD_LOAD_USER_DATA
,
userDataKey
,
1
,
""
,
""
);
return
;
}
String
keyFilePath
=
getUserDataDirRoot
()
+
"/"
+
ABVDataCache
.
getInstance
().
getMemberInfo
().
loginId
+
"/"
+
ABVEnvironment
.
getInstance
().
userDataKeyFile
;
FileInputStream
fi
=
null
;
InputStreamReader
isr
=
null
;
try
{
StringBuffer
sb
=
new
StringBuffer
();
fi
=
new
FileInputStream
(
keyFilePath
);
isr
=
new
InputStreamReader
(
fi
,
StandardCharsets
.
UTF_8
);
int
data
;
while
((
data
=
isr
.
read
())
!=
-
1
)
{
sb
.
append
((
char
)
data
);
}
isr
.
close
();
afterABookCheckApi
(
ABookKeys
.
CMD_LOAD_USER_DATA
,
userDataKey
,
0
,
""
,
sb
.
toString
());
}
catch
(
FileNotFoundException
fnfex
)
{
}
catch
(
IOException
e
)
{
}
finally
{
try
{
if
(
isr
!=
null
)
{
isr
.
close
();
}
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
}
}
public
void
commonAttachedDataUrl
(
String
taskKey
,
String
data
)
{
boolean
isError
=
false
;
...
...
@@ -1245,7 +1370,7 @@ public abstract class ABVContentViewActivity extends ABVAuthenticatedActivity {
}
public
void
afterABookCheckApi
(
final
String
cmd
,
final
String
taskKey
,
final
int
result
,
final
String
message
,
final
String
extParam
,
final
boolean
isParent
)
{
Logger
.
v
(
TAG
,
"run javaScript for ABookCheck : cmd=%s, taskKey=%s, result=%s, message=%s"
,
cmd
,
taskKey
,
result
,
message
);
Logger
.
d
(
TAG
,
"run javaScript for ABookCheck : cmd=%s, taskKey=%s, result=%s, message=%s"
,
cmd
,
taskKey
,
result
,
message
);
final
String
finalParent
=
isParent
?
"window.parent."
:
""
;
runOnUiThread
(
new
Runnable
()
{
@Override
...
...
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