Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
G
galaxy-iOS
Project
Project
Details
Activity
Releases
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
mobile-group
galaxy-iOS
Commits
5d75db48
Commit
5d75db48
authored
Oct 10, 2025
by
Steven杜宇
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'dev_1013' of
http://gitlab.galaxy-immi.com/mobile-group/galaxy-iOS
into dev_1013
parents
bdfddd18
4bebd8ee
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
74 additions
and
30 deletions
+74
-30
YHCirclePublishViewController.swift
...ty(社区)/Circle(下属社区)/C/YHCirclePublishViewController.swift
+49
-12
YHCircleViewController.swift
...Community(社区)/Circle(下属社区)/C/YHCircleViewController.swift
+6
-3
YHDynamicItem.swift
...asses/Modules/Mine(我的)/NameCard(名片)/M/YHDynamicItem.swift
+1
-0
YHDynamicViewModel.swift
...Modules/Mine(我的)/NameCard(名片)/VM/YHDynamicViewModel.swift
+4
-4
YHSelectMediaItem.swift
...asses/Modules/PictureReview(图片预览)/YHSelectMediaItem.swift
+3
-1
YHOSSManager.swift
galaxy/galaxy/Classes/Tools/Upload/YHOSSManager.swift
+11
-10
No files found.
galaxy/galaxy/Classes/Modules/Community(社区)/Circle(下属社区)/C/YHCirclePublishViewController.swift
View file @
5d75db48
...
@@ -160,9 +160,19 @@ class YHCirclePublishViewController: YHBaseViewController {
...
@@ -160,9 +160,19 @@ class YHCirclePublishViewController: YHBaseViewController {
return
view
return
view
}()
}()
init
(
currentUser
:
UserInfo
?
=
nil
,
id
:
String
?
=
nil
)
{
init
(
currentUser
:
UserInfo
?
=
nil
,
id
:
String
?
=
nil
,
mediaItems
:
[
YHSelectMediaItem
]?
=
nil
,
title
:
String
?
=
nil
,
content
:
String
?
=
nil
)
{
self
.
currentUser
=
currentUser
self
.
currentUser
=
currentUser
self
.
circleId
=
id
self
.
circleId
=
id
if
let
mediaItems
=
mediaItems
{
self
.
mediaItems
=
mediaItems
}
if
let
title
=
title
{
//
}
if
let
content
=
content
{
//
}
super
.
init
(
nibName
:
nil
,
bundle
:
nil
)
super
.
init
(
nibName
:
nil
,
bundle
:
nil
)
}
}
...
@@ -329,6 +339,7 @@ class YHCirclePublishViewController: YHBaseViewController {
...
@@ -329,6 +339,7 @@ class YHCirclePublishViewController: YHBaseViewController {
}
}
@objc
private
func
publishButtonTapped
()
{
@objc
private
func
publishButtonTapped
()
{
view
.
endEditing
(
true
)
guard
hasContent
()
else
{
guard
hasContent
()
else
{
YHHUD
.
flash
(
message
:
"请至少添加一张图片"
)
YHHUD
.
flash
(
message
:
"请至少添加一张图片"
)
return
return
...
@@ -372,17 +383,46 @@ class YHCirclePublishViewController: YHBaseViewController {
...
@@ -372,17 +383,46 @@ class YHCirclePublishViewController: YHBaseViewController {
let
content
=
detailTextView
.
text
??
""
let
content
=
detailTextView
.
text
??
""
// 调用你的发布接口
// 调用你的发布接口
YHHUD
.
show
(
.
progress
(
message
:
"发布中..."
))
viewModel
.
publishCircle
(
title
,
content
,
resources
:
resources
)
{
[
weak
self
]
success
,
error
in
viewModel
.
publishCircle
(
title
,
content
,
resources
:
resources
)
{
[
weak
self
]
success
,
error
in
guard
let
self
=
self
else
{
return
}
guard
let
self
=
self
else
{
return
}
if
success
{
YHHUD
.
hide
()
self
.
completion
?()
if
let
success
=
success
,
!
success
.
isEmpty
{
self
.
dismiss
(
animated
:
true
)
// self.completion?()
self
.
dismiss
(
animated
:
true
)
{
[
weak
self
]
in
guard
let
self
=
self
else
{
return
}
self
.
gotoCircleDetailPage
(
id
:
success
)
}
}
else
{
}
else
{
YHHUD
.
flash
(
message
:
error
?
.
errorMsg
??
"发布失败"
)
YHHUD
.
flash
(
message
:
error
?
.
errorMsg
??
"发布失败"
)
}
}
}
}
}
}
private
func
gotoCircleDetailPage
(
id
:
String
)
{
var
url
=
YHBaseUrlManager
.
shared
.
businessH5Url
()
+
"/community/activity/
\(
id
)
"
if
YHLoginManager
.
shared
.
isLogin
()
{
let
token
=
YHLoginManager
.
shared
.
h5Token
let
urlHasParam
=
String
.
hasQueryParameters
(
urlString
:
url
)
if
urlHasParam
{
url
=
url
+
"¶m="
+
token
}
else
{
url
=
url
+
"?param="
+
token
}
}
var
tUrl
=
url
if
!
url
.
contains
(
"navigationH="
)
{
tUrl
=
url
+
"?navigationH=
\(
k_Height_NavigationtBarAndStatuBar
)
"
if
url
.
contains
(
"?"
)
{
tUrl
=
url
+
"&navigationH=
\(
k_Height_NavigationtBarAndStatuBar
)
"
}
}
let
vc
=
YHH5WebViewVC
()
vc
.
url
=
tUrl
UIViewController
.
current
?
.
navigationController
?
.
pushViewController
(
vc
)
}
// MARK: - Keyboard Handling
// MARK: - Keyboard Handling
@objc
private
func
keyboardWillShow
(
notification
:
NSNotification
)
{
@objc
private
func
keyboardWillShow
(
notification
:
NSNotification
)
{
guard
let
keyboardFrame
=
notification
.
userInfo
?[
UIResponder
.
keyboardFrameEndUserInfoKey
]
as?
CGRect
,
guard
let
keyboardFrame
=
notification
.
userInfo
?[
UIResponder
.
keyboardFrameEndUserInfoKey
]
as?
CGRect
,
...
@@ -569,19 +609,16 @@ extension YHCirclePublishViewController: UICollectionViewDataSource, UICollectio
...
@@ -569,19 +609,16 @@ extension YHCirclePublishViewController: UICollectionViewDataSource, UICollectio
item
.
uploadState
=
.
uploading
item
.
uploadState
=
.
uploading
viewModel
.
uploadImage
(
image
,
true
)
{
[
weak
self
,
weak
item
]
success
,
error
in
viewModel
.
uploadImage
(
image
,
true
)
{
[
weak
item
]
success
,
error
in
guard
let
self
=
self
,
let
item
=
item
else
{
return
}
guard
let
item
=
item
else
{
return
}
let
imageUrl
=
(
success
??
""
)
.
getCdnUrl
()
if
let
error
=
error
{
guard
!
imageUrl
.
isEmpty
else
{
item
.
uploadState
=
.
failed
item
.
uploadState
=
.
failed
if
let
error
=
error
{
item
.
uploadError
=
error
item
.
uploadError
=
error
printLog
(
"上传失败:
\(
item
.
name
)
, error:
\(
error
)
"
)
printLog
(
"上传失败:
\(
item
.
name
)
, error:
\(
error
)
"
)
return
return
}
}
let
imageUrl
=
(
success
??
""
)
.
getCdnUrl
()
guard
!
imageUrl
.
isEmpty
else
{
item
.
uploadState
=
.
failed
return
return
}
}
...
...
galaxy/galaxy/Classes/Modules/Community(社区)/Circle(下属社区)/C/YHCircleViewController.swift
View file @
5d75db48
...
@@ -109,13 +109,16 @@ private extension YHCircleViewController {
...
@@ -109,13 +109,16 @@ private extension YHCircleViewController {
guard
let
self
=
self
else
{
guard
let
self
=
self
else
{
return
return
}
}
DispatchQueue
.
global
()
.
async
{
DispatchQueue
.
global
()
.
async
{
self
.
arr
.
removeAll
()
let
tempArr
=
self
.
viewModel
.
dynamicArr
self
.
arr
.
append
(
contentsOf
:
(
self
.
viewModel
.
dynamicArr
))
for
item
in
tempArr
{
for
item
in
self
.
arr
{
item
.
calHeightParam
()
item
.
calHeightParam
()
}
}
DispatchQueue
.
main
.
async
{
DispatchQueue
.
main
.
async
{
self
.
arr
.
removeAll
()
self
.
arr
.
append
(
contentsOf
:
tempArr
)
self
.
noDataView
.
isHidden
=
self
.
arr
.
count
>
0
self
.
noDataView
.
isHidden
=
self
.
arr
.
count
>
0
self
.
circleCollectView
.
reloadData
()
self
.
circleCollectView
.
reloadData
()
self
.
circleCollectView
.
es
.
stopLoadingMore
()
self
.
circleCollectView
.
es
.
stopLoadingMore
()
...
...
galaxy/galaxy/Classes/Modules/Mine(我的)/NameCard(名片)/M/YHDynamicItem.swift
View file @
5d75db48
...
@@ -22,6 +22,7 @@ class YHDynamicListModel: SmartCodable {
...
@@ -22,6 +22,7 @@ class YHDynamicListModel: SmartCodable {
class
YHResourceURLs
:
SmartCodable
{
class
YHResourceURLs
:
SmartCodable
{
var
name
:
String
=
""
var
name
:
String
=
""
var
url
:
String
=
""
var
url
:
String
=
""
// 1图片2视频
var
type
:
Int
=
0
var
type
:
Int
=
0
var
width
:
String
=
"0"
var
width
:
String
=
"0"
var
height
:
String
=
"0"
var
height
:
String
=
"0"
...
...
galaxy/galaxy/Classes/Modules/Mine(我的)/NameCard(名片)/VM/YHDynamicViewModel.swift
View file @
5d75db48
...
@@ -109,7 +109,7 @@ extension YHDynamicViewModel {
...
@@ -109,7 +109,7 @@ extension YHDynamicViewModel {
/// - content: 内容
/// - content: 内容
/// - resources:图片/视频数组
/// - resources:图片/视频数组
/// - callBackBlock: 回调
/// - callBackBlock: 回调
func
publishCircle
(
_
title
:
String
,
_
content
:
String
,
resources
:
[
YHResourceURLs
],
callBackBlock
:
@escaping
(
_
success
:
Bool
,
_
error
:
YHErrorModel
?)
->
Void
)
{
func
publishCircle
(
_
title
:
String
,
_
content
:
String
,
resources
:
[
YHResourceURLs
],
callBackBlock
:
@escaping
(
_
success
:
String
?
,
_
error
:
YHErrorModel
?)
->
Void
)
{
var
params
:
[
String
:
Any
]
=
[
"title"
:
title
,
"content"
:
content
]
var
params
:
[
String
:
Any
]
=
[
"title"
:
title
,
"content"
:
content
]
params
[
"resource_urls"
]
=
resources
.
map
{
resource
in
params
[
"resource_urls"
]
=
resources
.
map
{
resource
in
[
[
...
@@ -124,13 +124,13 @@ extension YHDynamicViewModel {
...
@@ -124,13 +124,13 @@ extension YHDynamicViewModel {
_
=
YHNetRequest
.
postRequest
(
url
:
strUrl
,
params
:
params
)
{
json
,
_
in
_
=
YHNetRequest
.
postRequest
(
url
:
strUrl
,
params
:
params
)
{
json
,
_
in
if
json
.
code
==
200
{
if
json
.
code
==
200
{
callBackBlock
(
true
,
nil
)
callBackBlock
(
json
.
data
?
.
peel
as?
String
,
nil
)
}
else
{
}
else
{
let
error
:
YHErrorModel
=
YHErrorModel
(
errorCode
:
Int32
(
json
.
code
),
errorMsg
:
json
.
msg
)
let
error
:
YHErrorModel
=
YHErrorModel
(
errorCode
:
Int32
(
json
.
code
),
errorMsg
:
json
.
msg
)
callBackBlock
(
false
,
error
)
callBackBlock
(
nil
,
error
)
}
}
}
failBlock
:
{
err
in
}
failBlock
:
{
err
in
callBackBlock
(
false
,
err
)
callBackBlock
(
nil
,
err
)
}
}
}
}
}
}
galaxy/galaxy/Classes/Modules/PictureReview(图片预览)/YHSelectMediaItem.swift
View file @
5d75db48
...
@@ -12,6 +12,7 @@ class YHSelectMediaItem {
...
@@ -12,6 +12,7 @@ class YHSelectMediaItem {
var
name
:
String
var
name
:
String
var
type
:
YHMediaType
var
type
:
YHMediaType
var
image
:
UIImage
?
var
image
:
UIImage
?
var
imageURL
:
URL
?
var
videoURL
:
URL
?
var
videoURL
:
URL
?
var
duration
:
TimeInterval
?
var
duration
:
TimeInterval
?
...
@@ -27,10 +28,11 @@ class YHSelectMediaItem {
...
@@ -27,10 +28,11 @@ class YHSelectMediaItem {
case
failed
// 上传失败
case
failed
// 上传失败
}
}
init
(
name
:
String
=
""
,
type
:
YHMediaType
=
.
image
,
image
:
UIImage
?
=
nil
,
videoURL
:
URL
?
=
nil
,
duration
:
TimeInterval
?
=
nil
)
{
init
(
name
:
String
=
""
,
type
:
YHMediaType
=
.
image
,
image
:
UIImage
?
=
nil
,
imageURL
:
URL
?
=
nil
,
videoURL
:
URL
?
=
nil
,
duration
:
TimeInterval
?
=
nil
)
{
self
.
name
=
name
self
.
name
=
name
self
.
type
=
type
self
.
type
=
type
self
.
image
=
image
self
.
image
=
image
self
.
imageURL
=
imageURL
self
.
videoURL
=
videoURL
self
.
videoURL
=
videoURL
self
.
duration
=
duration
self
.
duration
=
duration
}
}
...
...
galaxy/galaxy/Classes/Tools/Upload/YHOSSManager.swift
View file @
5d75db48
...
@@ -97,13 +97,14 @@ class YHOSSManager: NSObject, URLSessionDelegate {
...
@@ -97,13 +97,14 @@ class YHOSSManager: NSObject, URLSessionDelegate {
func
putObject
(
image
:
UIImage
,
_
isPublic
:
Bool
=
false
,
callBackBlock
:
@escaping
(
_
success
:
String
?,
_
error
:
YHErrorModel
?)
->
Void
)
{
func
putObject
(
image
:
UIImage
,
_
isPublic
:
Bool
=
false
,
callBackBlock
:
@escaping
(
_
success
:
String
?,
_
error
:
YHErrorModel
?)
->
Void
)
{
let
request
=
OSSPutObjectACLRequest
()
let
request
=
OSSPutObjectACLRequest
()
let
size
=
picMaxSize
let
size
=
picMaxSize
DispatchQueue
.
global
()
.
async
{
guard
let
imageData
=
image
.
compressOriginalImage
(
size
)
else
{
guard
let
imageData
=
image
.
compressOriginalImage
(
size
)
else
{
DispatchQueue
.
main
.
async
{
callBackBlock
(
nil
,
YHErrorModel
())
callBackBlock
(
nil
,
YHErrorModel
())
}
return
return
}
}
DispatchQueue
.
global
()
.
async
{
request
.
uploadingData
=
imageData
request
.
uploadingData
=
imageData
if
isPublic
{
if
isPublic
{
request
.
bucketName
=
self
.
publicModel
.
bucket
request
.
bucketName
=
self
.
publicModel
.
bucket
...
@@ -116,7 +117,7 @@ class YHOSSManager: NSObject, URLSessionDelegate {
...
@@ -116,7 +117,7 @@ class YHOSSManager: NSObject, URLSessionDelegate {
let
dateFormatter
=
DateFormatter
()
let
dateFormatter
=
DateFormatter
()
dateFormatter
.
dateFormat
=
"yyyyMMdd"
dateFormatter
.
dateFormat
=
"yyyyMMdd"
let
currentDateMMdd
=
dateFormatter
.
string
(
from
:
Date
())
let
currentDateMMdd
=
dateFormatter
.
string
(
from
:
Date
())
self
.
fileName
.
append
(
name
)
//
self.fileName.append(name)
if
isPublic
{
if
isPublic
{
request
.
acl
=
"public-read-write"
request
.
acl
=
"public-read-write"
request
.
objectKey
=
"5000000"
+
"/"
+
currentDateMMdd
+
"/"
+
"
\(
name
)
"
request
.
objectKey
=
"5000000"
+
"/"
+
currentDateMMdd
+
"/"
+
"
\(
name
)
"
...
@@ -138,19 +139,19 @@ class YHOSSManager: NSObject, URLSessionDelegate {
...
@@ -138,19 +139,19 @@ class YHOSSManager: NSObject, URLSessionDelegate {
let
result
=
t
let
result
=
t
if
result
.
error
!=
nil
{
if
result
.
error
!=
nil
{
callBackBlock
(
nil
,
YHErrorModel
())
callBackBlock
(
nil
,
YHErrorModel
())
self
.
fileName
.
removeFirst
()
//
self.fileName.removeFirst()
}
else
{
}
else
{
let
dateFormatter
=
DateFormatter
()
let
dateFormatter
=
DateFormatter
()
dateFormatter
.
dateFormat
=
"yyyyMMdd"
dateFormatter
.
dateFormat
=
"yyyyMMdd"
let
currentDateMMdd
=
dateFormatter
.
string
(
from
:
Date
())
let
currentDateMMdd
=
dateFormatter
.
string
(
from
:
Date
())
var
string
=
""
var
string
=
""
if
isPublic
{
if
isPublic
{
string
=
"https://"
+
self
.
publicModel
.
bucket
+
"."
+
"oss-cn-shenzhen.aliyuncs.com/"
+
"5000000"
+
"/"
+
currentDateMMdd
+
"/"
+
"
\(
self
.
fileName
.
first
??
""
)
"
string
=
"https://"
+
self
.
publicModel
.
bucket
+
"."
+
"oss-cn-shenzhen.aliyuncs.com/"
+
"5000000"
+
"/"
+
currentDateMMdd
+
"/"
+
"
\(
name
)
"
}
else
{
}
else
{
string
=
"https://"
+
self
.
model
.
bucket
+
"."
+
"oss-cn-shenzhen.aliyuncs.com/"
+
"4001001"
+
"/"
+
currentDateMMdd
+
"/"
+
"
\(
self
.
fileName
.
first
??
""
)
"
string
=
"https://"
+
self
.
model
.
bucket
+
"."
+
"oss-cn-shenzhen.aliyuncs.com/"
+
"4001001"
+
"/"
+
currentDateMMdd
+
"/"
+
"
\(
name
)
"
}
}
callBackBlock
(
string
.
getPrivateUrl
(),
YHErrorModel
())
callBackBlock
(
string
.
getPrivateUrl
(),
YHErrorModel
())
self
.
fileName
.
removeFirst
()
//
self.fileName.removeFirst()
}
}
return
return
})
.
waitUntilFinished
()
})
.
waitUntilFinished
()
...
...
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